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METHOD AND SYSTEM FOR IMPLEMENTING A REDUCED COMPLEXITY 

DUAL RATE ECHO CANCELLER 

FIELD OF THE INVENTION 

The present invention relates generally to echo cancellers and, more particularly, 
5 to dual rate echo cancellers for simultaneous support of multiple annexes. 

BACKGROUND OF THE INVENTION 

The advent of the Internet and the widespread popularity of personal computers 
have created an unprecedented demand for high bandwidth networks. Generally, Internet 

10 applications, from simple email to real time video conferencing, from web surfing to 
interactive movies, from interactive games to virtual TV stations, from online trading to 
online gambling, demand a higher bandwidth communication network. A fundamental 
challenge for the communication industry is to provide a reliable and affordable high 
bandwidth communication link to all types of Internet users. Various competing wire- 

15 line, wireless, and optical broadband technologies are deployed to partially meet the ever- 
increasing demand for higher bandwidth. The fastest growing broadband technology is 
the Digital Subscriber Line (DSL) technology, which provides a high bandwidth always- 
on connection over standard twisted pair copper media of the conventional telephone 
network. Among other wire-line media, coaxial cables are capable of providing always- 

20 on connections, however, its presence is insignificant compared to millions and millions 
of wired telephone customers who are connected by a twisted pair of copper wires. Other 
technologies, such as satellite, wireless, and optical, either provide limited coverage, 
limited bandwidth, or are too expensive for deployment to individual customers. As a 
result, DSL technology is uniquely positioned to provide the broadband link between 

25 individual customer premise and the central office, the so-called last-mile of the high- 
bandwidth communication network. 

DSL is the fastest growing among emerging broadband technologies for very 
good reasons. First of all, DSL utilizes the existing copper wire network infrastructure. 
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Secondly, compared to the voice modems, such as V.34 and V.90, used in most personal 
computers that provide up to 56 kbps dial-up connection, DSL provides a high bandwidth 
always-on connection with typical connection speeds from 384 kbps to 6 Mbps. 
Moreover, DSL is affordable with easy installation, simple turn-up, and high service 
5 reliability. The successful deployment of DSL is capable of providing digital broadband 
connection to anyone with an analog telephone line. 

DSL services have been standardized over time by regional organizations such as, 
American National Standard Institute (ANSI), European Telecommunication Standard 
Institute (ETSI), and by world telecommunication organization International 

10 Teleconmiunication Union (ITU). These DSL standards define data communication 
protocols to connect customer premise equipment (CPE) to the central office (CO) and to 
provide connections to various networks, such as DSL service providers, virtual private 
networks (VPN), or the Internet. Various forms of digital data (e.g., voice, video, and 
data) can be transported using DSL technology. For transport of voice, DSL equipment 

15 is connected to the public switched telephone network (PSTN). For transport of video 
and data, DSL equipment uses the Internet via an Internet service provider (ISP). Voice 
over DSL (VoDSL) is capable of providing computer-to-computer, computer-to- 
telephone, and telephone-to-telephone voice services using an integrated access device 
(IAD). Video over DSL includes transport of MPEG-1 or MPEG-2 files, video 

20 conferencing using Internet Protocol (IP) standard such as ITU H.323, WebCam, and 
video mail. In addition, DSL supports simple data transport, e.g., bearer services, for 
virtual private network (VPN), leased data line such as Tl and El, Point-to-Point 
Protocol (PPP), Asynchronous transfer mode (ATM), and Internet Protocol (ff ). 

Like other communication technologies, DSL has gone though a major evolution 
25 over the last decade and a collection of technologies, commonly referred to as xDSL, are 
developed under the umbrella of DSL. One type of subscriber loop digital transmission 
technology involves an integrated services digital network (ISDN), which has replaced a 
significant portion of the analog phone lines in Europe and Japan. ISDN offers integrated 
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voice and data services and connection speed up to 144 kbps. Due to the high cost of 
deployment, an alternative solution called integrated digital loop carrier (IDLC) was 
deployed in United States. However, resulting data rates were considered inadequate for 
individual customers. As a result, advanced DSL technologies were developed including 
5 HDSL, SDSL, ADSL, HDSL2, SHDSL, and VDSL, all of which are capable of 
connection speed in excess of 1Mbps. These advanced DSL technologies were 
developed to address different needs and application demands, while serving different 
market segments. For example, SHDSL is a symmetric service designed for long reach 
office applications with connection speed of 1.5Mbps, whereas, VDSL is designed to 
10 provide a very high-speed asymmetric service for a short-range applications. 

An achievement of DSL technologies is the use of fewer wires for transmission. 
For example, compared to high speed subscriber line (HDSL) technology, developed in 
the late '80s that requires a minimum of 4 copper wires, HDSL2, ADSL, and SHDSL all 
use 2 copper wires. Transnndtting and receiving signals at the same time over the same 

15 wire-pair achieves this reduction in the number of copper wires. This technique is known 
as full-duplex transmission. Conventional wire line communication systems use an 
analog four-to-two wire conversion circuit, called a hybrid circuit, to achieve full duplex 
transmission over a single wire pair. In this configuration, transmit and receive paths 
share the same wire pair through the hybrid circuit. As a result, the transmit signal leaks 

20 into the receive path whenever perfect balance is not achieved in the hybrid circuit. The 
part of the transmit signal that leaks into the receive path is referred to as an echo signal. 

Generally, echo is created when a transmitted signal is reflected back through a 
hybrid circuit, which includes a four-to-two wire interface that comprises a transformer 
and a balanced load to match the average impedance of the various lines, into the near- 
25 end receiver. A typical passive analog hybrid generally provides less than 20 decibels 
(dB) of average return loss from the transmitter to the near-end receiver, while more than 
70 dB is required to achieve high rate data transmission applications. The echo signal, if 
not adequately suppressed, can severely degrade the performance of the full-duplex 
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digital transmission system. This is especially true for medium and long loop lengths 
where the received signal strength can be lower than that of the echo signal due to the 
line loss. Unfortunately, in any real application the line characteristics are variable and 
unknown. Thus, it is difficult to exactly match the line conditions by a passive analog 
5 hybrid circuit. Under these conditions, a traditional analog hybrid circuit provides an 
insufficient level of echo suppression. Echo cancellation generally involves separating 
two signals traveling simultaneously in opposite directions in the same wire pair over the 
same frequency bands. Estimating and canceling the echo produced by the leakage of the 
transmitted signal into the receiver may achieve separation. Echo cancellation may be 
10 used to increase the reach or noise margin of an ADSL system by allowing both upstream 
and downstream channels to use the low frequency portion of twisted pair spectrum. 

Digital echo cancellers are commonly used to suppress the echo to an adequate 
level and to recover the performance loss due to the echo. Hence, digital echo cancellers 
are an integral part of high performance full-duplex systems. In wire line communication 

15 systems with full-duplex transmission over a single wire pair, digital echo cancellers are 
commonly used to suppress the echo of the transmit signal entering the receive path. In 
an echo-cancelled system, the transmit signal may be filtered using an echo cancellation 
filter (ECF) to generate a reliable copy of the echo signal before subtracting it from the 
received signal. Implementation of digital echo cancellers is well understood for 

20 appUcations such as symmetric DSL (e.g., High-Speed Digital Subscriber Line HDSL2 or 
G.shdsl) with identical transmit and receive rates. However, for applications such as 
ADSL and Very High Bit Rate Digital Subscriber Line (VDSL) with asymmetric data 
rates, the sample rates of transmit and receive paths need to be adequately bridged or 
matched. Though such rate matching function is crucial for efficient implementation of 

25 the echo cancellers, currently there is no effective approach to achieve rate matching. 

For example, a full rate ADSL system, such as that specified by the International 
Telecommunications Union (ITU) Standard G.992.1, may support full duplex 
transmission over a single wire pair. To achieve such full duplex transmission, digital 
echo cancellers may be implemented for ADSL to suppress the echo of the transmit 
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signal entering the receive path. However, ADSL is generally designed to support 
asymmetric data rates, e.g., transmit and receive rates are not identical for an ADSL 
transceiver. In particular, at a Customer Premise Equipment (CPE), the receive data rate 
is generally higher than the transmit data rate. Moreover, G.992.1 specifies different 
5 transmit bandwidths for the CPE according to the region specific Annexes. For example, 
the Annex A is designed for North American deployment, Annex B is for European 
countries and annex C is for Japan. Thus, echo cancellers may be required to bridge such 
disparity between sample rates of transmit and receive paths. Though such rate matching 
function is crucial for efficient implementation of echo cancellers, there is no obvious 

10 approach to achieve rate matching. 

A much longer adaptive echo canceller filter operating at the higher receive 
sample rate may be used to achieve satisfactory results at the cost of increased total 
computation, power, and silicon area. Furthermore, with longer filters, the training 
algorithm is more prone to diverge. Another alternative involves using frequency- 

15 domain echo cancellation schemes, which requires a more complex hardware/software 
design and is not as flexible as the time-domain filter approach, in terms of steady state 
tracking, for example. 

The use of a time-domain adaptive echo cancellation filter operating at the higher 
sample rate of the transmit and receive paths is standard practice in communication 

20 system design. For Discrete multi-tone (DMT) systems, alternative echo cancellation 
schemes may include data-driven multi-tone echo cancellers, frequency domain echo 
cancellation, and discrete multi-tone echo cancellation. Traditional echo cancellation 
schemes generally use a combination of time and frequency-domain operations to reduce 
the computational complexity associated with the training and operation of a 

25 conventional echo canceller. Furthermore, these traditional echo cancellation schemes 
generally require extra design in hardware and/or software to access frequency-domain 
information. These frequency-domain based designs also have potential problems in 
terms of steady-state tracking. A significantly larger echo cancellation filter (ECF) 
operating at a higher rate is generally required. Moreover, the conventional approach 
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requires a higher precision arithmetic. All of which require more hardware resources and 
computational power. 

Therefore, there is a need in the art of echo cancellers for a more efficient method 
and system for providing echo cancellation in dual rate applications and near optimal and 
5 low complexity adaptive implementations. 

SUMMARY OF THE INVENTION 

Aspects of the present invention overcome the problems noted above, and realize 
additional advantages. One such inventive aspect provides methods and systems for 
implementing a reduced complexity dual rate echo canceller for simultaneous support of 
10 multiple annexes. One aspect of this invention relates to an efficient Reduced 
Complexity Dual Rate Echo Chancellor (RCDR-EC) architecture for ADSL CPE for 
M: simultaneous support of a plurality of annexes, such as Annex A and Annex B of 

G.992.1. In addition, low complexity LMS update rules are proposed for adaptive 
rU training RCDR-EC. Other voice coder standards may be supported for added versatility 

15 and improved functionality. In addition, RCDR-EC of the present invention may operate 
^{t at the transmit rate, the lower of the two rates, thereby requiring less computation per 

s data sample. The present invention provides an echo canceller structure for full rate 

m ADSL CPE. Another aspect of the present invention is directed to designing the echo 

J^; canceller flexible enough to simultaneously support, at least, Annex A and Annex B of 

20 G.992.L Another aspect of the present invention is further directed to obtaining an 
efficient rate matching echo canceller implementation for full rate ADSL CPE as well as 
other applications. 

According to an embodiment of the present invention, a dual rate echo canceller 
for simultaneous support of a plurality of annexes comprises an annex selector for 
25 selecting at least one of a plurality of annexes; an echo cancellation filter having an input 
adapted to receive a transmit signal, the echo cancellation filter being adapted to generate 
an output signal comprising a signal component representative of an echo signal 
associated with the transmit signal, wherein the echo cancellation filter operates at a 



-6- 



PATENT 

Attorney Docket No. 56162.000357 



transmit rate; and an output up sampling block having an input adapted to receive the 
output signal, the output up sampling block being adapted to generate an up-sampled 
signal by a factor associated with a selected annex. 

Other aspects of the present invention may include the up-sampled signal 
5 generated by a zero filling operation; wherein the echo cancellation filter is an adaptive 
finite impulse response filter; an interpolation filter having an input adapted to receive the 
up-sampled signal, the interpolation filter being adapted to generate a first filtered output 
at a receive rate, wherein the first filtered output is subtracted from an incoming signal to 
generate a residual echo signal; wherein the interpolation filter is a fixed or 
10 programmable low pass finite impulse response filter for interpolating the up-sampled 
signal; an anti-aliasing filter having an input adapted to receive the residual echo signal, 
the anti-aliasing filter adapted to generate a second filtered output at a receive rate; 
C3 wherein the anti-aliasing filter is a fixed or programmable low pass finite impulse 

response filter for filtering out frequency signals above a transmit band; a down sampling 

It ?r/ 

G 15 block having an input adapted to receive the second filtered output, the down sampling 
block being adapted to generate a down sampled output signal at a transmit rate by a 
factor associated with a selected annex; a delay block having an input adapted to receive 

it: 

H an input transmit signal, the delay block being adapted to generate a delayed transmit 

signal for compensating for a delay in the echo signal; an up sampling block having an 

W 20 input adapted to receive an input transmit signal, the up sampling block being adapted to 
generate an up-sampled signal by a factor associated with one of a plurality of factors for 
a plurality of annexes, wherein an output of the input up-sampled block is coupled to an 
input of the echo cancellation filter; wherein the plurality of annexes comprise Annex A 
and Annex B of G,992.1 as well as G.dmt, G.lite, and G.992.2; wherein the down 
25 sampled output signal comprises an error signal for adaptively at least one training 
coefficient of the echo cancellation filter; wherein least mean square update rules are 
used to adaptively train the at least one coefficient of the echo canceller filter. 

According to another embodiment of the present invention, a method for 
implementing a dual rate echo canceller for simultaneous support of a plurality of 
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annexes comprises the steps of selecting at least one of a plurality of annexes; receiving a 
transmit signal; generating an output signal comprising a signal component representative 
of an echo signal associated with the transmit signal at a transmit rate; receiving the 
output signal; and generating an up-sampled signal by a factor associated with a selected 
5 annex. 

Other aspects of the present invention may include the up-sampled signal 
generated by a zero filling operation; wherein the echo cancellation filter is an adaptive 
finite impulse response filter; the steps of receiving the up-sampled signal; and generating 
a first filtered output at a receive rate, wherein the first filtered output is subtracted from 
10 an incoming signal to generate a residual echo signal; the step of implementing a fixed or 
programmable low pass finite impulse response filter for interpolating the up-sampled 
signal; the steps of receiving the residual echo signal; and generating a second filtered 
p output at a receive rate; the step of implementing a fixed or programmable low pass finite 

J": impulse response filter for filtering out frequency signals above a transmit band; the steps 

Q 15 of receiving the second filtered output; and generating a down sampled output signal at a 
transmit rate by a factor associated with a selected annex; the steps of receiving an input 
transmit signal; and generating a delayed transmit signal for compensating for a delay in 
H the echo signal; the steps of receiving an input transmit signal; and generating an up- 

sampled signal by a factor associated with one of a plurality of factors for a plurality of 
K 20 annexes, wherein an output of the input up-sampled block is coupled to an input of an 
I^-, echo cancellation filter; wherein the plurality of annexes comprise Annex A and Annex B 

of G.992.1, G.dmt, G.lite, and G.992.2; wherein the down sampled output signal 
comprises an error signal for adaptively at least one training coefficient of an echo 
cancellation filter; and wherein least mean square update rules are used to adaptively 
25 train the at least one coefficient of the echo canceller filter. 

BRIEF DESCRIPTION OF THE DRAWINGS 
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The present invention can be understood more completely by reading the 
following Detailed Description of the Invention, in conjunction with the accompanying 
drawings, in which: 

FIG. la is a block diagram illustrating a digital echo canceller, according to an 
embodiment of the present invention. 

FIG. lb is a system diagram illustrating a digital echo canceller implementation, 
according to an embodiment of the present invention. 

FIG. Ic is a system diagram illustrating a TEQ implementation, according to an 
embodiment of the present invention. 

FIG. Id is a system diagram illustrating modem transmission, according to an 
embodiment of the present invention. 

FIG. 2 is a block diagram illustrating an echo canceller, according to an 
embodiment of the present invention. 

FIG. 3 is a block diagram illustrating an example of a dual rate echo canceller, 
according to an embodiment of the present invention. 

FIG. 4 is a block diagram illustrating an example of a dual rate echo canceller, 
according to an embodiment of the present invention. 

FIG. 5 is a block diagram of a CPE side dual rate echo canceller for simultaneous 
support of multiple annexes, according to an embodiment of the present invention. 

FIG. 6 is an example of an impulse response of IF and AAF, according to an 
embodiment of the present invention. 

FIG. 7 is a convolution of IF and AAF impulse response, according to an 
embodiment of the present invention. 

FIG. 8 is a block diagram illustrating an example of a weighted vector error echo 
canceller, according to an embodiment of the present invention. 
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FIG. 9 is a flowchart illustrating an update process, according to an embodiment 
of the present invention. 

FIG. 10a is a block diagram of a TEQ system, according to an embodiment of the 
present invention illustrating a fractionally spaced TEQ. 

FIG. 10b is a block diagram of a TEQ system, according to an embodiment of the 
present invention illustrating a sample spaced TEQ, 

FIG. 10c is a block diagram of a TEQ system, according to an embodiment of the 
present invention illustrating a hypothetical model of a delay sample transmit signal for 
determining TEQ filter coefficients. 

FIG. 11 presents a flow chart of the method in accordance with the current 
invention. 

FIG. 12 presents a flow chart describing a method of calculating the TEQ filter 
vector of the present invention. 

FIG. 13 presents a flow chart of the steps of calculating TIR ({bk}) and TEQ 
({wk}) filter coefficients using MLC-TEQ. 

FIGs. 14a and 14b are schematic diagrams of hardware architectures in which the 
inventive aspects of the present invention may be incorporated. 

FIG. 15 is a block diagram of a physical media dependent layer of a ADSL CPE 
chip in which the inventive aspects of the present invention may be incorporated. 

FIG. 16 is a block diagram of a transmission convergence layer of a ADSL CPE 
chip in which the inventive aspects of the present invention may be incorporated. 

FIG. 17 is a block diagram of an analog front end device in which the inventive 
aspects of the present invention may be incorporated. 

FIGs. 18a- 18c are block diagrams of appHcations in which the inventive aspects 
of the present invention may be incorporated. 
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LIST OF ACRONYMS 

• A/D - Analog To Digital 

5 • AAF - Anti- Aliasing Filter 

• ADC - Analog to Digital Converter 

• ADSL - Asymmetric Digital Subscriber Line 

• AECF - Adaptive Echo Cancellation Filter 

• AFE - Analog Front End 

10 • AGC - Automatic Gain Control 

• AOC - ADSL Overhead Control 

• ANSI - American National Standard Institute 

• ARM - Advanced RISC Machine 

• ASIC - Application-Specific Integrated Circuit 
15 • ATM - Asynchronous Transfer Mode 

• BIU - Bus Interface Unit 

• CIR - Channel Impulse Response 

• CLECs - Competitive Local Exchange Carriers 
y • CLK- Clock 

fr; 20 • CO - Central Office 

p CPE - Customer Premise Equipment 

M> • CRC - Cyclic Redundancy Check 

'=^1 • CRL - Clock Recovery Loop 

^ ^ • CSR - Control and Status Registers 

25 • DAC - Digital to Analog Converter 

f • D/A - Digital To Analog 

|I • dB - Decibels 

m • DMA - Direct Memory Access/Addressing 

U • DMT - Discrete Multi-Tone 

30 • DP - DMT Processor 

• DSB - Down Sampling Block 

• DSL - Digital Subscriber Line 

• DSLAM - DSL Access Multiplexor/Module 

• DSP - Digital Signal Processing 

35 • EEPROM - Electrically Erasable Programmable Read Only Memory 

• EC - Echo Canceller 

• ECF - Echo Cancellation Filter 

• EOC - Embedded Overhead Control 

• EPB - Extemal Peripheral Bus 

40 • Eth PHY - Ethernet Physical Layer 

• ETSI - European Telecommunication Standard Institute 
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EWMP - Error Weighting Multi-input-multi-output Filter 

FDD - Frequency Division Duplex 

FEC - Forward Error Correction 

FEQ - Frequency Domain Equalization 

FIFO - First In First Out 

FIR - Finite Impulse Response 

GPIO - General Purpose Input/Output 

HDLC - High-Level Data Link Control 

HDSL - High-Speed Digital Subscriber Line 

HIU - Host Interface Unit 

IAD - Integrated Access Device 

ICE - Information and Content Exchange 

ICE - In-Circuit Emulator 

ICI - Inter Channel or Carrier Interference 

IDLC - Integrated Digital Loop Carrier 

IF - Interpolation Filter 

VF - Interface 

IFB - Interpolation Filter Bank 

IFFT - Inverse Fast Fourier Transform 

ILECs - Incumbent Local Exchange Carriers 

IP - Internet Protocol 

IPF - Interpolation Filter 

ISDN - Integrated Services Digital Network 

ISI - Inter Symbol Interference 

ISOS - Integrated Software on Silicon 

ISP - Internet Service Provider 

rrU - International Telecommunications Union 

DCCs - Interexchange Carriers 

JEDEC - Joint Electronic Device Engineering Counsel 

JTAG - Joint Test Action Group 

LD - Line Driver 

LMS - Least Mean Square 

LPF - Low Pass Filter 

LTI - Linear Time-Invariant 

MAC - Media Access Control 

MCM - Multi Chip Module 

Mil - Media Independent Interface 

MIPS - Million Instructions Per Second 

MIMO - Multi-Input Multi-Output 

MMSE - Minimum Mean Squared Error 

MSE - Mean Squared Error 
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• NP - Network Processor 

• NTR - Network Timing Reference 

• 0AM - Operation, Administration and Maintenance 

• OSI - Open Source Initiative 

5 • PAC - Programmable Attenuation Control 

• PCI - Peripheral Component Interconnect 

• PGA - Programmable Gain Amplifier 

• PHY - Physical Layer Device 

• PMS - Physical Media Specific 
10 • PP - Protocol Processor 

• PPP - Point-to-Point Protocol 

• PROM - Programmable Read Only Memory 

• PSD - Power Spectral Density 

• PSTN - Public Switched Telephone Network 

15 • RCDR-EC - Reduced Complexity Dual Rate Echo Canceller 

• RMB - Rate Matching Block 

• RMB-RT - Rate Matching Block from Receive to Transmit 

• RMB-TR - Rate Matching Block from Transmit to Receive 

• ROM - Read Only Memory 
20 • RS - Reed Solomon 

• RSIF - Reference Signal Interpolation Filter 

• Rx - Receive 

• SD - Sigma-Delta 

• SDRAM - Synchronous Dynamic Random Access Memory 
25 • SNMP - Simple Network Management Protocol 

• SNR - Signal To Noise Ratio 

• SRAM - Static Random Access Memory 

• STM - Synchronous Transfer Mode 

• SVD - Singular Value Decomposition 
30 • TC - Transmission Convergence 

• TEQ - Time Domain Equalizers 

• TIR - Target Impulse Response 

• Tx - Transmit 

• UART - Universal Asynchronous Receiver Transmitter 
35 • USB - Up Sampling Block 

• USB - Universal Serial Bus 

• VCXO - Voltage Controlled Crystal Oscillator 

• VDSL - Very High Bit Rate Digital Subscriber Line 

• VoDSL - Voice over Digital Subscriber Line 
40 • VoIP - Voice over Internet Protocol 

• VPN - Virtual Private Network 
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• VU - Vectorization Unit 

• WEVE-EC - Weighted Vector Error Echo Canceller 

5 DETAILED DESCRIPTION OF THE INVENTION 

The following description is intended to convey a thorough understanding of the 
invention by providing a number of specific embodiments and details involving echo 
cancellers. It is understood, however, that the invention is not limited to these specific 
embodiments and details, which are exemplary only. It is further understood that one 

10 possessing ordinary skill in the art, in light of known systems and methods, would 
appreciate the use of the invention for its intended purposes and benefits in any number 
of alternative embodiments, depending upon specific design and other needs. 

According to an embodiment of the present invention, a dual rate echo canceller is 
provided for applications with asymmetric transmit and receive rates. In particular, the 

15 present invention provides Reduced Complexity Dual Rate Echo Canceller (RCDR-EC) 
architecture along with low complexity Least Mean Square (LMS) update rules. 
According to one aspect, the present invention is directed to an echo canceller that 
provides rate matching functionality for applications (e.g., ADSL, VDSL, etc.) with 
asymmetric data rates. 

20 The RCDR-EC architecture and LMS update rules of the present invention 

provide various features and advantages. For example, RCDR-EC may operate at the 
lower of the two rates, receive and transmit, requiring less computation per data sample. 
RCDR-EC implements a significantly smaller length echo cancellation filter (ECF) for 
achieving the same (or similar) level of echo suppression of conventional 

25 implementations. This reduces the hardware requirement for implementation of RCDR- 
EC. Due, in part, to the reduction in ECF length, RCDR-EC may involve significantly 
less computation for filtering operation in steady state. The reduced rate and smaller 
echo canceller length enables RCDR-EC training to be simplified where less computation 
is required for adaptive training of the RCDR-EC. In addition, inherent out-of-band 

30 noise rejection capability of RCDR-EC enables adaptive training to require less time to 
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converge. Moreover, out-of-band noise rejection enables the adaptive training algorithm 
to yield an improved RCDR-ECF resulting in enhanced echo suppression. 

The present invention provides an efficient rate matching echo canceller for 
applications with asymmetric transmit and receive rates, such as ADSL and VDSL, for 
5 example. Another aspect of the present invention provides echo canceller structures for 
cases involving higher and lower receive rates as compared to the transmit rate. Another 
aspect of the present invention is directed to developing a low complexity LMS update 
for adaptive training of the echo cancellation filters. In addition, the present invention 
reduces hardware requirements for implementation of the echo canceller and reduces 
10 computational requirements for steady state operation of the echo canceller. As a result, 
overall performance of the echo canceller is improved. 

A basic block diagram of the digital echo canceller structure 100, which may be 
1:3 employed in central office (CO), CPE or other equipment, is shown in FIG. la. A 

transmit filter 1 10 receives an input transmit signal from a transmit path and generates a 
O 15 filtered transmit signal. The output of transmit filter 110 may be received by analog front 
end (AFE) 112, which is comprised of digital to analog converter and various analog 
components including line drivers, for example. Echo cancellation filter (ECF) 122 
M: receives an input from the output of the transmit filter and generates a copy of an echo 

|T signal by a linear filtering operation. The output generated by AFE 1 12 may be received 

S 20 at an input of Analog Hybrid 114, which is comprised of various passive analog 
iU, components, for example, and may be coupled to a twisted wire pair or other 

transmission line. A receive signal may be received by analog hybrid 114, which may be 
coupled to AFE 116 at a receive side. For example, analog hybrid 114 may include 
common analog components, such as resistors and capacitors. The output generated by 
25 AFE 116 is received at an input of receive filter 118. The receive filter performs linear 
filtering operation and attempts to suppress out of band noise. The copy of the echo 
signal generated by ECF 122 is subtracted from the receive signal generated by receive 
filter 118, at summer 120. The resulting residual signal may be used to train echo 
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cancellation filter 122, such as by feeding a sampling signal 121 into echo cancellation 
filter 122. 

As shown in FIG. la, digital echo cancellation may be achieved by obtaining a 
reliable copy of the echo signal, which may be generated from the transmit signal using a 
5 filter, such as a Finite Impulse Response (FIR) ECF, as illustrated by 122. The copy of 
the echo signal is then subtracted from the received signal. The FIR ECF 122 operates as 
a connecting branch between the transmit and receive paths. For example, the echo 
canceller filter receives an input from the transmit path and generates an output for the 
receive path. Hence, the ECF 122 accommodates the rate transition from the input 
10 transmit rate to the output receive rate. For applications, such as symmetric DSL (e.g., 
HDSL2, G.shdsl, etc.), where the transmit and receive data rates are identical there is 
generally little or no need for rate transition. As a result, implementation of ECF is 
straightforward in these cases. However, for applications such as ADSL and VDSL and 
^ for other applications that support asymmetric transmit and receive data rates, rate 

;□ 15 transition may be required at the ECF. As addressed by the present invention, there are 
l] different approaches to achieve the rate transition within the ECF. In accordance with an 

fy embodiment of the present invention, ECF 122 may incorporate the inventive features as 

Ij, discussed in detail below. 

FIG. lb is a system diagram illustrating a digital echo canceller implementation, 
Cy 20 according to an embodiment of the present invention. In particular, system 130 illustrates 
;f echo cancellation functionality in a DSL modem system. CO side DSL modem is 

represented by 132, which may include a DSL modem 134 transmitting to and receiving 
from Hybrid and Analog Front End 138. Echo cancellation filter 136 compensates for a 
portion of the transmit signal that is received as an echo signal as shown by arrow 137. 
25 CO side DSL modem 132 may be connected to CPE DSL modem 142 by a twisted 
copper pair 140. CPE DSL modem 142 may include a DSL modem 144 transmitting to 
and receiving from Hybrid and Analog Front End 148. Echo cancellation filter 146 
compensates for a portion of the transmit signal that is received as an echo signal as 
shown by arrow 147. The inventive aspects of the echo cancellation filter as described in 
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detail below may be incorporated into echo cancellation filter represented by 136 and 
146. 

FIG. Ic is a system diagram illustrating a TEQ implementation, according to an 
embodiment of the present invention. In particular, system 150 represents TEQ in a 
5 DMT based DSL modem. CO Side DSL Modem 152 may include DMT transmitter 154, 
Transmit Filter 156, Analog Front End 158, Receive filter 160, TEQ 162 and DMT 
receiver 164. CO Side DSL Modem 152 is coupled to CPE DSL modem 168 via twisted 
copper pair 166. CPE DSL modem 168 may include DMT transmitter 170, Transmit 
Filter 172, Analog Front End 174, Receive filter 176, TEQ 178 and DMT receiver 179. 
10 The inventive aspects of the TEQ features as described in detail below may be 
incorporated into TEQ represented by 162 and 178. 

]^ FIG. Id is a system diagram illustrating modem transmission, according to an 

f;3 embodiment of the present invention. At the CO end, various sources of data may be 

^ transmitted via a DSL modem, as represented by 182, which may further include DSL 

15 Access Module, DSL AM, for example. Internet 184 may provide data, such as video and 

rij other forms of data, via Internet Service Provider 183. ATM Network 186 may provide 
data, such as video and other forms of data, via ATM Switch 185. Public Switch 

rU Network (PSTN) 188 may provide voice data to Central Office Switch 187. DSL modem 

il.-H., 

m 1 82 may receive the various forms of data and conmiunicate via a twisted copper pair 

53 20 1 81 at a CPE device. At the CPE end, data from DSL modem 182 may be received by 
DSL modem CPE 192. Voice data may be received by splitter 190 for transmission to a 
telephone 191 or other voice device. DSL modem CPE 192 may transmit data to a 
computer 193 or other device. Video data may be received by set top box 194 for 
transmission to television (TV) 195 or other video device. The inventive aspects of the 
25 echo cancellation features as well as the TEQ features may be incorporated in this 
system, in accordance with the various embodiments of the present invention as 
discussed in detail below. 
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Generally, the receive data rate is a rational multiple of the transmit data rate, as 
illustrated by 

Rrx = CCRtxy 

where a = P/Q for co-prime integers P and Q (e.g., P and Q do not have any 
5 common factors). Rtx and Rrx represent the sampling rates at the output of the transmit 
and the receive filters, respectively, la one example, a > 1 may represent cases, such as 
ADSL CPE, where the receive rate is higher than the transmit rate. On the other hand, a 
< 1 may represent cases, such as ADSL CO, where the receive rate is lower than the 
transmit rate. Depending on the value of a, different Reduced Complexity Dual Rate 
10 Echo Canceller (RCDR-EC) structures may be implemented. 

FIG. 2 is a block diagram of an echo canceller, according to an embodiment of the 
present invention. Sampling may occur by rate matching as represented by 220. In one 
example, FIG. 2 represents an echo canceller for applications where the receive rate is 
higher than the transmit rate. A transmit filter 210 may receive a transmit signal and 
15 generate a filtered transmit signal. The output of the transmit filter 210 may be coupled 
to an analog front end or other device. A copy of an echo signal associated with the 
transmit signal may be up-sampled by Up Sampling block 212 to match the sample rate 
Hi! to the receive rate. The up-sampled signal may then be received by Echo Cancellation 

'l^ Filter 214 to produce an output at the receive rate. The resulting output may be 

p 20 subtracted from a received signal filtered by Receive filter 216. Conventional echo 
cancellers generally operate the ECF at the higher receive rate. As a consequence, the 
ECF, which may be a Finite Impulse Response (FIR), may require a larger number of 
taps to span a fixed length of time. As a result, extra hardware or software complexities 
will result. In accordance with the present invention. Echo Cancellation Filter 214 may 
25 include the inventive aspects of the invention, as discussed in detail below. 

FIG. 3 illustrates a block diagram of a Reduced Complexity Dual Rate Echo 
Canceller (RCDR-EC), according to an embodiment of the present invention. In 
particular, FIG. 3 illustrates a case where the receive rate is higher than the transnndt rate. 
As shown in FIG. 3, a transmit filter 310 may receive a transmit signal from a transmit 
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path and generate a filtered transmit signal Transmit filter 310 may operate at a 

transmit rate (RtxX The output x(n) of the transmit filter 210 may be received by an 
analog front end or other device. Echo Cancellation Filter (ECF) 312 may include an 
adaptive FIR filter that receives an input from the transmit path and generates a copy of 
5 an echo associated with the transmit signal, as shown by xl(n), ECF 312 may operate at 
transmit rate {Rtx). Since both the input and output of ECF 312 are sampled at the lower 
transmit rate (Rtx). the ECF 312 operates at the lower transmit rate (Rtx). 

Rate Matching Block from Transmit to Receive (RMB-TR) 320 up-samples the 
output jcl(n) of ECF 312 by a factor a with appropriate filtering wherein a = P/Q. The 
10 RMB-TR 320 may further include sub blocks, such as an Up Sampling Block (USB-P) 
322 with up sampling factor P, an Interpolation Filter (IFF) 324, and a Down Sampling 
Block 326 (DSB-Q) with down sampling factor Q. Other sub-blocks may be 
J;^J implemented. 

An output xl(n) of the ECF 312 may be received by the USB-P 322. An up 
;if 15 sampUng function at the USB-P 322 may be achieved by a zero filling operation, e.g., the 
USB-P inserts P-l zeros between consecutive input signal samples. Other operations for 

ru 

«^ achieving up sampling may be implemented. Thus, USB-P 322 may generate samples P 

times faster than the input sample rate Rtx* 
l[i An output x2(l) of the USB-P 322 may be received by the EPF 324, The IPF 324 

J^I 20 may inchide a fixed FIR filter that interpolates the up-sampled signal. Essentially, IPF 
324 may serve as a low pass filter for filtering out most or all P-l replicas of the transmit 
signal generated from the up sampling function. The IPF 324 may operate at P times the 
transmit rate Rtx or other variation thereof. 

An output x3(l) of the IPF 324 may be received by the DSB-Q 326. The DSB-Q 
25 326 may down sample the output of the IPF 324 by a factor Q by dropping QA samples 
from the input data stream and generating a signal at the receive rate Rrx> 

An incoming receive signal from an Analog Front End may be received by 
Receive Filter 314, which operates at a receive rate Rrx^ Receive Filter 314 may then 
generate a filtered receive signal y(m). The output x4{m) of the RMB-TR 320 may then 
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be subtracted from the filtered receive signal y{m) from Receive Filter 314 at summer 316 
to generate a residue echo signal er{m). 

Rate Matching Block from Receive to Transmit (RMB-RT) 330 may down 
sample the residue echo signal er{m) by a factor a (or other factor) with appropriate 
5 filtering. Similar to RMB-TR 320, the RMB-RT 330 may include sub blocks, such as Up 
Sampling Block (USB-Q) 332 with up sampling factor Q, an Anti-Aliasing Filter (AAF) 
334, and a Down Sampling Block (DSB-P) 336 with down sampling factor F. 

The residue echo signal e^pi) may be received by the USB-Q 332. The up 
sampling at the USB-Q 332 may be achieved by a zero filling operation, e.g., the USB-Q 
10 332 inserts Q-1 zeros between consecutive input signal samples. Other operations for 
achieving up sampling may be implemented. Thus, USB-Q 332 may generate samples Q 
times faster than the input sample rate Rrx^ 
Q An output elQ) of the USB-Q 332 may be received by the AAF 334. The AAF 

fy 334 may include a fixed low pass FIR filter that receives the up-sampled output of the 

;f 15 summer 3 16 and filters out most or all the high frequency signals above the transmit band 
H before feeding it to a down-sampling block. The AAF 334 may operate at Q times the 

receive rate Rr^. 

jf: An output e2{l) of the AAF 334 may be received by the DSB-P 336. The DSB-P 

2 5; 

336 may down sample the output of the AAF 334 by a factor P (or other factor) by 
K 20 dropping P-l samples from the input data stream and generating an error signal e{n) at 
1^=^ the transmit rate 

In one particular embodiment, for RCDR-EC of the present invention, the up 
sampling is accomplished after the ECF 312, as opposed to the conventional approach 
where up sampling is done before EFC 312. 
25 The transmit signal x(n) may first be filtered by a N-tap FIR ECF where 

represents adaptable ECF filter coefficients. The output of the ECF may be written as 

N 

xlin)= ^ X (n - A: + l)wjt = x\w. 
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where Xn is the data vector 

Xn [jc(n), x(n - 1), x(n - 2), . . . x(n - + 1)]^, 
w is the coefficient vector, 

W [Wi, W2, VV3, ... WNf, 

5 and T denotes the transpose operation. 

According to another embodiment of the present invention, the RMB-TR 320 may 
up-sample xl{n) by a factor a. For example, for every P input samples the RMB-TR 320 
may generate Q output samples where a = P/Q, As discussed above, the up sampling at 
the USB-P 322 may be achieved by a zero filling operation. Other operations for 

10 achieving up sampling may be implemented. The output x2{l) of the USB-P 322 may be 
expressed as 

Jxl(n), ifl^Pn 
[0 otherwise 

In other words, x2(l) may include the samples of xl{n) with P - 1 zeros inserted in 
15 between, e.g., samples of x2(l) may be given as follows: 

• • -0, xl(n - 1),0,0, • " ,0, xl(n)A ' ' ' 

^ — — ' 

P~l zeros 

Different time indices may be used to represent different sampling rates, e.g., n, /, 
and m may be used to represent rates Rtxy PRtx (or equivalently, QRrx). and Rrx, 
respectively, for example. 
20 The output of a Nf tap FIR PF 324 may be given by 

^/ 



x3(l)= Xx2(/-/:+l)/,, 



where 

represent the IPF coefficients. 
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The output x3(l) of the TPF 324 may be down sampled using DSB-Q 326 where 
the output may be represented by 

x4(m) - jc3(/), where / = Qm. 

In other words, xA{m) may include decimated samples of x3(n\ where the samples 
5 of x4(n) may be written as 

...,x3(2(/- I)),x3(2/),x3(e(/+ 1)X ... 
The output of RMB-TR 320 may be subtracted from the inconaing receive signal 
y(m) from 314 to generate the residue echo signal er(m), which may be defined as 

erim) = y{m) - x4(m). 

10 The residue echo signal er{m) may be up-sampled by USB-Q 332 by zero filling 

(or other operation) where the output may be given by 

UrimX ifl = Qm 
el{i) = < 

[0 otherwise. 

The up-sampled signal el(l) may be filtered by the AAF 334, which may be a FIR 
15 filter, to generate the filtered version e2(/), which may be expressed as 

e2(l)= ^el(l-k + l)g,, 

where 

{gUg2.g3. ... gNg} 

are a Ng AAF coefficients. 
20 The output e2(/) of the AAF 334 may be down sampled using DSB-P 336 to 

generate the error signal e(n) which may be defined as 

e(n) - elil), where / = Pn, 

25 PF 324 and/or AAF 334 may include low pass filters that filter out the high 

frequency signals above the transmit band. According to an embodiment of the present 
invention, the same (similar or related) coefficients may be used for both IFF and AAF, 
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e.g., = gi, for all L Also, the samples of the error signal may be generated at the 
transmit rate Rtx^ The error signal e(n) may then be used to adaptively train the 
coefficients of ECF 312, as discussed below. 

To describe the LMS update rules for the RCDR-EC structure of the present 
invention, the error signal e(n) may be expressed in terms of the transmit signal x(n) and 
the receive signal y(m) as well as IPF and AAF coefficients. For example, the error 
signal e(n) may be written as 

e{n) = yAn) - h%w, 

where yr{n) is the received signal component after USB-Q 332, AAF 334, and DSB-P 
336, w is the ECF coefficient vector. 



x„ 



x(n) jc(n-l) 
x(n — 1) x(n — 2) 



x(n-iV + l) 
xin-N) 



xin-L + V) x{n-L) ■■■ xin-L-N + 2) 



'a «f 



15 



20 



is the L X N input data matrix, and 

h [huhz,h3, ...hif, 
is the filter coefficients vector that represents the combined effect of IPF 324 and AAF 
334 along with the effects of USB-P 322, DSB-Q 326, USB-Q 332, and DSB-P 336. 

The DSB-Q 326 and USB-Q 332 may have a sub-sampling effect on the IPF 324 
and AAF 334 coefficients, e.g., the equivalent filters may include one of the possible Q 
phases of the original filters. For example, /^^ may denote one of possible Q phases of 
the IPF filter 324, where 



fk^ =fQ(k - i)+qh for A: = 1 , 2, . . . Nf, 



25 In addition, qi % 1, 2, 3, ... , Q denotes the selected phase where Nf is the smallest 
integer not less than Nf/Q. Similarly, for the AAF coefficients. 
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giP = gQ(k -D+qu for /c = 1 , 2, . . . Ng^ 

where q2X\,2,3, ... , Q denotes the selected phase and is the smallest integer not 
5 less than Ng/Q. 

The {Np + - 1) coefficients of the combined filter response of the single 
phase IPF 324 and AAF 334 may be represented by bi. For example, bi may be obtained 
by convolving/t^ and g/^ as follows: 

10 bi=Y,hU^i-M, forZ=l,2,...,A7^/+A^g -1. 

k 

From the combined filter coefficients bu the elements of h may be easily obtained. 
The effect of USB-P 322 and DSB-P 336 may include the selection of a phase out of 
possible P phases. In other words. 



15 



hi - bp{i . 1) for / = 1, 2 , . . . , L, 



where /? x 1^ 2, 3, ... , P denotes the selected phase and L is the smallest integer not less 
than {Np + A^^^ - 1)/P. Though the exact value of p, qu and qi may not significantly 
20 impact the performance, the a priori knowledge of these integers may be used to 
calculate h. In the equations, the value in parenthesis generally refers to the time and 
variables in bold generally refer to arrays (e.g., vec(n) refers to values of the array "vec" 
at time n). 

Once the expression for the error signal e{n) is obtained, the LMS update rule 
25 may be given as follows: 



w„+i =Wrt-//^(n)X/h, 
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where // is the LMS step size. Time subscript for Wn may represent the LMS iteration. 

At a first glance, it may appear that the proposed LMS update requires (L + 1)A^ 
multiplications per iteration where the factor L is due to the vector-matrix product X/h. 
However, due to the shift structure of e.g., X„ may be a Hankel (or other) matrix, per 

5 iteration, N multiplications may be used instead. Hence, the over all computational 
complexity of the LMS for RCDR-EC may be IN multiplications per iteration. The 
multiplication required may be twice that of usual LMS which in comparison requires N 
multiplications. As a result, there is a savings of filter coefficients by, at least, a factor a. 
Thus, the computational complexity of the proposed LMS for RCDR-EC of the present 

10 invention is lower for a > 2. 

According to another embodiment of the present invention, a simplified LMS may 
be implemented to reduce computational complexities by using an approximation on h. 
In one example, IPF 324 and/or AAF 334 may include low pass filters. Hence, the 
impulse responses may be similar to a sine function, hi other words, the impulse 

15 response has a dominant peak and diminishes in magnitude away from the peak. 
Moreover, the convolution of two such filters may also exhibit a similar behavior. 
Variations may be made to h. For example, the largest element of h may be replaced 
with its sign. In another example, some or the rest of the elements may be set to zero (or 
other value). Replacing the largest magnitude element by its sign may result in a scaling 

20 of h where such scaling may be absorbed in fi. In addition, no approximation may be 
involved in this step. After such scaling, the remaining elements may have a magnitude 
less than one, which may then be approximated to zero. With this approximation, the 
coefficient vector h becomes a vector of zeros except one non-zero element (e.g., ± 1). 
Without loss of generality, the largest magnitude element of h may be positive and the 

25 matrix-vector product may reduce to a delayed version of the input vector, e.g., 
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XTT 
n n = 



x(n - d) 
x{n-d-\) 

x{n-d-N + \) 



where h is the approximate h and d is the index of the largest element of h. 
Using this approximation, the LMS update may simplify to, 



where Xn is the data vector defined before as 

p 10 Xn = [x{n\ x(n - 1), x(n - 2), x(n - N + I )] . 

C3 Hence, the simplified LMS update for RCDR-EC may be similar to the normal 

I J LMS update except for the delay. In other words, the computational complexity of the 

^ W simplified LMS for RCDR-EC is similar to that of usual LMS. 

15 Since both IPF and AAF are part of the system design, the approximation does 

;^ not restrict the use of the simplified LMS. The IPF and AAF may be defined such that 

CO the resulting combined filter has a single dominant coefficient. Factors that may degrade 

il the convergence and performance of LMS may include multiple dominant peaks in the 

combined filter response and inexact setting of the delay d, for example. 
20 Since up sampling in the USB-P may be performed by zero filling, the sub blocks 

of RMB-TR 330 may be combined for efficient poly-phase implementation. The poly- 
phase implementation of RMB-TR may require RrxN/P (or equivalently, RtxN/Q) 
multiplications per second. Efficient poly-phase structure may also be used for RMB-RT 
330 and the number of multiplications that may be required per second is RtxN/Q. 
25 Various comparisons may be made between a conventional echo canceller and the 

RCDR-EC of the present invention for the case a > 1, for example. 
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As for structural differences, a conventional echo canceller is generally composed 
of an up sampling block followed by an adaptive FIR ECF that operates at the higher 
receive rate Rrx- In contrast, in the RCDR-EC approach of the present invention the 
adaptive FIR ECF may operate at the lower transmit rate Rtx^ A rate matching block 

5 RMB-TR 330 may be used to generate echo samples at the receive rate and another rate 
matching RMB-RT 320 may be used to calculated the error signal at the transmit rate. 

As for filter lengths, to capture the same (or similar) fixed amount of time span 
(e.g., echo tail), the RCDR-EC of the present invention may use N filter taps as compared 
to the oN taps required by the conventional echo canceller approach. However, in 

10 addition to the ECF, RCDR-EC of the present invention may implement additional filters, 
which may include DPF and AAF. In general, the ECF is longer than the combined length 
of PF and AAF. Hence, there is a significant reduction in the number of filter taps. For 
example, for a typical value of iV = 256 and a = 8, the conventional filter requires 
approximately 2048 taps. According to an example of the present invention, even with 

15 two 64 taps IFF and AAF filters, the number of taps for RCDR-EC is approximately 384, 
significantly less than that required by conventional systems. 

As for LMS training computations, the computational complexity may be 
approximately equal (or similar) for the conventional LMS and simplified LMS for 
RCDR-EC of the present invention. However, since the conventional ECF is a times 

20 longer than that of RCDR-EC of the present invention, the number of multiplications 
required for LMS update may be a times higher for conventional echo canceller. Due to 
the reduction in the filter taps, LMS for RCDR-EC of the present invention has lower 
complexity then the conventional approach for a > 2, according to one example of the 
present invention. 

25 As for steady state computational complexity, in steady state using efficient poly- 

phase implementation the total number of multiplications per second that may be required 
by RCDR-EC is (A^ + N/Q + Ng/Q)Rtx^ In contrast, even with efficient poly-phase 
implementation, the number of multiplications per second required by the conventional 
echo canceller is at least oNRrx- In a typical application, the total filter length of ff F and 
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AAF may be considered small compared to the length of the ECF filter, e.g., Nf+Ng<N, 
Hence, RCDR-EC of the present invention may reduce the steady state computation by at 
least a factor of a^. 

As for improved noise floor level and overall performance, in RCDR-EC the AAF 
5 filters out signals above a transmit band before generating the error signal e(n). Thus, the 
error signal has a reduced contribution from the wide band receive signal which acts as 
noise for echo cancellers. In a conventional echo canceller, the receive signal, even the 
part outside of the transmit band, contributes to the error signal. Hence, RCDR-EC of the 
present invention has a lower noise floor that results in reduced convergence time and 
10 improved overall performance of the LMS training algorithm. Other comparisons as well 
as advantages may be recognized by the present invention and variations thereof. 

FIG. 4 is a block diagram of a Reduced Complexity Dual Rate Echo Canceller 
(RCDR-EC), according to an embodiment of the present invention. The block diagram 
of FIG. 4 may support applications, such as ADSL CO, where the receive rate is lower 
15 than the transmit rate, e.g., a < 1. 

Transmit Filter 410 may receive a transmit signal from a transmit path and 
generate a filtered transmit signal x(n). The filtered transmit signal x(n) may be an input 
to an Analog Front End or other device. 

Rate Matching Block (RMB) 420 may up-sample the input signal by a factor a (or 
20 other factor) with appropriate filtering. The RMB 420 may include sub blocks, such as 
an Up Sampling Block with up sampling factor P (USB-P) 422, an Anti-Aliasing Filter 
(AAF) 424, and a Down Sampling Block with down sampling factor Q (DSB-Q) 426. 

The filtered transmit signal x(n) may be received by the USB-P 422. The up 
sampling at the USB-P 422 may be achieved by a zero filling operation, e.g., the USB-P 
25 422 may insert P-1 zeros between consecutive input signal samples. Other operations for 
achieving up sampling may be implemented. Thus, USB-P 422 generates samples P 
times faster than the input sample transmit rate Rtx. 

An output xl(n) from the USB-P 422 may serve as an input to the AAF 424. The 
AAF 424 may include a fixed low pass FIR filter that receives the up-sampled signal 
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xl(n) and filters out most or all the high frequency signals above the receive band before 
feeding it to a down-sampling block. AAF 424 may operate at P times the transmit rate 
Rtx. 

An output x2(n) from the AAF 424 may serve as an input to the DSB-Q 426. The 
5 DSB-Q 426 may down sample the output of the AAF 424 by a factor Q by dropping Q - 
1 samples from the input data stream and generate the output signal z(m) at the receive 
rate Rrx- 

Echo Cancellation Filter (ECF) 428 may include an adaptive FIR filter that 
receives the down sampled signal z(m) and generates a copy of the echo. Since both the 
10 input and output of the ECF 428 are sampled at the lower receive rate (Rrx), the ECF 428 
operates at the receive rate Rrx^ According to an embodiment of the present invention, 
RCDR-EC provides down sampling before the ECF, wherein ECF operates at the lower 
receive rate Rrx* 

The transmit signal x(n) may be up-sampled and filtered by the FIR AAF 424 
15 before being down sampled by the DSB-Q 426. The AAF 424 filters out most or all high 
frequency signals above the receive band. The down sampled signal at the output of the 
DSB-Q 426 may be denoted by z(m). The down sampled signal zQn) may then be filtered 
by the ECF 428 where the output of ECF 428 may be expressed as 

N 

20 zl(m) = ^z im-k+ l)wk = z/w, 

where Zm is the data vector 



25 



Zm [z(m\ z{m - 1), z{m - 2), . . . z(m - + 1)]^, 



w is the ECF coefficient vector. 
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A receive signal from Analog Front End may be filtered by Receive Filter 430. 
The output zl(m) of ECF 428 may then be subtracted from the incoming receive signal 
yim) to generate error signal e(m), e.g., 

e{m) = y{m) - zl(m). 



The samples of the error signal may be generated at the rate /?^. This error signal 
is then used to adaptively train the coefficients of ECF 428 as described in the following 
10 section. 

According to an embodiment of the present invention, an ECF input z(m) may not 
be the transmit signal but rather a down sampled version. Thus, to derive the LMS 
update rule for the RCDR-EC structure of the present invention, the error signal e(m) 
may be expressed in terms of the down sampled signal z(m), the receive signal y(m), and 
15 ECF coefficients as follows: 

^(m)=y(m)-z/w, 

where y{m) is the received signal, z„ is the data vector, and w is the ECF 
20 coefficient vector as previously discussed. 

Once the error signal e{n) has been defined, the LMS update rule may be given as 
follows: 



yi'm+l='Wm-f^eim)Zn, 

where is the LMS step size. Time subscript for may represent the LMS iteration. 

The above LMS update rule of the present invention may be similar to a LMS 
update except for the fact that the data vector is the down sampled version of the transmit 
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signal x{n), for example. Hence, the computational complexity of LMS update for 
RCDR-EC may be similar as that of the conventional LMS. 

According to another embodiment of the present invention, a dual rate echo 
canceller for simultaneous support of multiple annexes of G.992.1 (or ITU G.dmt) is 
provided. Other annexes and variations thereof may also be supported. The present 
invention provides an efficient Reduced Complexity Dual Rate Echo Chancellor (RCDR- 
EC) architecture for ADSL CPE for simultaneous support of a plurality of annexes, such 
as Annex A and Annex B of G.992.L In addition, low complexity LMS update rules are 
proposed for adaptive training RCDR-EC. 

The RCDR-EC architecture and LMS update rules of the present invention 
provide various features and advantages. The RCDR-EC structure of the present 
invention may be designed for digital echo cancellation for full rate ADSL at the CPE, 
for example. The proposed structure of the present invention may also support a plurality 
of annexes, such as at least both Annex A and Annex B of ITU Standard G.992.1, also 
known as G.dmt. Other standards, including wire-line technology, may be supported for 
added versatility and improved functionality. In addition, RCDR-EC of the present 
invention may operate at the transmit rate, the lower of the two rates, thereby requiring 
less computation per data sample. 

According to one example, the present invention provides an echo canceller 
structure for full rate ADSL CPE. Another aspect of the present invention is directed to 
designing the echo canceller flexible enough to simultaneously support, at least. Annex A 
and Annex B of G.992.1. Another aspect of the present invention is further directed to 
obtaining an efficient rate matching echo canceller implementation for full rate ADSL 
CPE as well as other applications. 

For example, the ADSL system, as specified in ITU standard G,992.1, may 
require full-duplex transmission over a single wire line thereby necessitating the 
separation of transmit and receive signals at the ADSL transceivers, such as the CPE. 
Typically, a passive analog circuit, e.g., a hybrid circuit, may be used for this purpose. In 
any realistic implementation, the transmit signal often leaks into the receive path 
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whenever perfect balance is not achieved in the hybrid circuit. The part of the transmit 
signal that leaks into the receive path is generally referred to as the echo signal. Even 
though a four-to-two wire conversion circuit has worked well for telephony application, 
the echo signal, if not adequately suppressed, may severely degrade the performance of 
5 full-duplex ADSL systems. Digital echo cancellers are commonly used at the ADSL 
transceiver to suppress the echo to an adequate level and to recover the performance loss 
due to the echo. 

ADSL systems support asymmetric transmit and receive data rates, where the 
echo canceller (EC) implemented in the system may be required to accommodate the rate 
10 difference. For ADSL systems, the upstream rate is generally higher than the 
downstream rate. In other words, for ADSL customer premises equipment the receive 
rate is generally higher than the transmit rate. In accordance with specifications 
recommended by the full rate ADSL ITU standard G.992.1, for example, the following 
may apply: 

15 Rrx-^MRt,. 

where M is an integer larger than 1, Rrx and Rtx are the sample rates of receive and 
transmit signals, respectively. The transmit bandwidth requirements may be different for 
region specific Annexes, e.g.. Annex A and Annex B of G.992.1, for example, and the 
value of M may depend on the particular Annex and/or other factors and conditions. 

20 The present invention provides a detailed implementation of Reduced Complexity 

Dual Rate Echo Canceller (RCDR-EC) structures for simultaneous support of, at least. 
Annex A and Annex B at the ADSL CPE, for example, as well as other applications. In 
addition, LMS update rules may be implemented for adaptive training of the RCDR-EC 
of the present invention. 

25 For ADSL CPE and other applications, where the receive rate is higher than the 

transmit data rate, the usual approach may involve up sampling the transmit signal to the 
match the receive rate before echo cancellation. As shown in FIG. 2 above, an up- 
sampled transmit signal may be filtered by the ECF to produce an output signal at the 
receive rate. 
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However, for such implementation, the ECF may operate at the higher receive 
rate and as a consequence the FIR ECF may require a larger number of taps to span a 
fixed length of time. Thus, extra hardware or software complexities may be needed. 
RCDR-EC of the present invention may operate at the lower transmit rate thereby 
5 reducing hardware and/or software complexities. 

FIG. 5 is a block diagram of a CPE-side echo canceller, according to an 
embodiment of the present invention. According to one example, the RCDR-EC may 
include a combination of a delay block 514, an Input Up Sampling Block 516, an Echo 
Cancellation Filter 520, an Output Up Sampling Block 522, an Interpolation Filter 526, 
10 an Anti-Aliasing Filter 532, and a Down Sampling Block 534. In addition, annex 
selectors 518, 524 and/or 536 may be included as well. An optional DC offset block 528 
^ may be incorporated. 

C3 A transmit signal may be received as an input to Inverse Fast Fourier Transform 

m (IFFT) filter 510 for generating a filtered transmit signal. The filtered transmit signal 

J'f 15 may be received by a Transmit Filter 512. A delay block 514 may receive the transmit 
' d signal for generating a delay in the input transmit samples. 

According to an embodiment of the present invention. Input Up Sampling Block 
(USB-I) 516 may up-sample the delayed transmit signal by a factor of 2 or 4 for Annex A 
and Annex B, respectively. The delayed transmit signal may be up-sampled by other 
20 factors as well, which may vary depending on the applications and/or other conditions. 
N The up sampling function may be achieved by zero filling. Other operations may be 

implemented for achieving the up sampling function. The output rate of the USB-I 516 
may be the transmit rate 7?^. 

Annex selector 518 may include a number of switches (e.g., three switches) for 
25 selecting a variety of annexes (e.g., Annex A or B). As shown in FIG. 5, by way of 
example, the switch position A and B denotes the respective Annexes. Other selections 
and/or options may be implemented. 

Echo Cancellation Filter (ECF) 520 may include an adaptive FIR filter that 
receives the up-sampled transmit signal x(n) and generates a copy of the echo, as shown 
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by jcl(n). As both the input x{n) and output xl{n) of the ECF 520 may be sampled at the 
lower transmit rate (Rtx), the ECF filter 520 may operate at the transmit rate Rtx- 

Output up sampling block (USB-0) 522 may receive the output xl(n) of the ECF 
520 and up-sample xl(n) by a factor of M. For example, the value of M may be 8 for 
5 Annex A and 4 for Annex B, where the selection may be made via annex selector 524. 
Other values of M may be assigned for other options. Other variations may be 
implemented. The up sampling function may be achieved by zero filling or other 
operation. 

The Interpolation Filter (IF) 526 may be a fixed FIR filter that interpolates the up- 

10 sampled signal x2(m). Essentially, the IF 526 may be a low-pass filter that filters out 
most or all Af-1 replica of the transmit signal generated due to up sampling. The IF 526 
may operate at the receive rate Rrx and generate an output x3{m) at the receive rate i?^. 
The output x3(m) of the IF 526 may be subtracted from an incoming receive signal y(m) 
to generate a residual echo signal er(m). 

15 Anti- Aliasing Filter (AAF) 532 may include a fixed low pass FIR filter that 

receives the residual echo signal er(m) and filters out most or all the high frequency 
signals above the transmit band before feeding the residual echo signal er(m) to the down- 
sampling block (DSB) 534. AAF 532 may operate at the receive rate J?;:^:- 

Down Sampling Block (DSB) 534 may down sample the output erf(m) of the AAF 

20 532 by a factor M and generate an error signal e{n) at the transmit rate Rtx^ For example, 
the value of M may be 8 for Annex A and 4 for Annex B, where the selection may be 
made via annex selector 536. Other values for M may be implemented for other annexes. 

For RCDR-EC of the present invention, the up sampling by a factor M (e.g., as 
performed by USB-O 522) may be performed after the ECF 520 as opposed to the 

25 conventional approach where up sampling is performed before the EEC 520. 

According to another embodiment of the present invention, the basic signal flow 
within RCDR-EC may be accomplished as follows: The transmit signal x{n) may be first 
delayed and then up-sampled. In the absence of the delay block 514, the ECF 520 may 
contain a leading sequence of zero coefficients, which may result in an inefficient use of 
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the filter coefficients. The leading zero coefficients may attempt to model the delay of 
the echo signal with respect to the transmit signal caused by various elements in the 
transmit path and the twisted pair line. The delay block 514 may be added to compensate 
for this delay of the echo signal and, hence, alleviate the burden for the ECF 520 to 
5 model the delay. According to an example of the present invention, the delay block 512 
is not an absolute requirement but may be added for improved efficient use of the ECF 
coefficients. 

For example, the highest sub-carrier for Annex A and B may be approximately 
around 138 and 276 kHz, respectively. As a result, even though the width of the transmit 

10 bands may be identical (or similar), Annex B transmit signal may require approximately 
twice the sampling rate for a passband sampling structure. The input up sampUng block 
(USB-I) 516 along with the annex selector 518 may be used to accommodate various 
sampling requirements. The output of the IFFT 510 may be sampled at a fixed rate, e.g., 
276 ks/s (kilo samples/sec), for example. After the USB-I 516, the transmit sample rates 

15 (Rfx) may be approximately equal to 552 ks/s and 1.104 Ms/s for Annex A and B, 
respectively. The up sampUng function may be performed by inserting zeros (e.g., 1 for 
Annex A and 3 for Annex B) in between consecutive samples of the input signals. Other 
operations may be used to perform the up sampling function. 

The up-sampled transmit signal may then be filtered by a N-tap FIR ECF 520, 

20 where x(n) may represent the up-sampled transmit signal and {wi, W2, ^^n}, may 

represent adaptable ECF coefficients. The output of the ECF 520 may then be written 
as: 

N 

k=i 

25 

where x„ is the data vector at time n represented by: 

Xn [jc(n), x(n - 1), x(n - 2), . . . x(n - + 1)]^; 
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w is the coefficient vector represented by: 



and T denotes the transpose operation. 

The USB-O 522 may up-sample xl(n) by a factor M. In other words, for every 
input sample, the USB-O 522 may generate M output samples. As mentioned before, the 
value of M may depend on (or be related to) the Annex type and/or other factors, e.g., 



10 M = 



8, for Annex A 
4, for Annex B. 
The up sampling function may be achieved by a zero filling operation (or other 
operation) and the output of the USB-O 522 may be expressed as: 

{xl{n), if m = Mn 
0 otherwise 

In other words, xl{m) may include samples of x\{n) with M-\ zeros inserted in 
15 between. For example, samples of x2(m) may be expressed as follows: 

• • - 0, xl(n - 1), 0,0, • • • ,0, xl(w),0, • • - 

M -1 zeros 



Different time indices (e.g., n and m) may be used to represent samples with 
20 different rates. For Annex A, n may denote a sampling rate of approximately 552 ks/s 
and for Annex B approximately 1.104 Ms/s. For both Annexes, m may denote a 
sampling rate of approximately 4.416 Ms/s. 

The output of A//- tap FIR IF 526 may be represented by: 

x3(m)= ^jc2(m-fc+l)/fc. 
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are IF 526 coefficients. 

The output of IF 526 may be subtracted from the incoming receive signal y(m) to 
generate the residual echo signal, e.g., 

er{m) = y{m) - x3(m). 
The residual echo signal er{m) may be filtered by the FIR AAF 532 to generate a 
filtered version Crf, which may be expressed as: 

k=l 

where 

[gugly §3, gNg] 

are Ng AAF 532 coefficients. 

The output of the AAF 532 may be down sampled using DSB 534 by a factor of 
M to generate the error signal e(n). In this case, the error signal e{n) may be expressed 
as: 

e(n) - erf{m)j where m = Mn. 

In other words, e(n) may include decimated samples of erf(n) where the samples 

of e{n) may be written as 

e^(M(n - 1)), erf(Mn\ erf{M(n + 1)), ... 
The value of M (e.g., 8 or 4) may be selected by the Annex selector 536. 

According to another embodiment of the present invention, the error signal may 
be used to adaptively train the coefficients of ECF 520. 

To describe the LMS update rules for RCDR-EC structure of the present 
invention, the error signal e(n) may be expressed in terms of the transmit signal x(n), the 
receive signal y{rri), and IF 526 and AAF 532 filter coefficients. The error signal e(n) 
maybe written as: 
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e{n) = yA^n) - h X„w, 

where yr(n) may be the received signal component after AAF 530 and DSB 532, w is the 
ECF 520 coefficient vector. 



X„ 



x(n) x(n - 1) 
x{n-l) x{n-2) 



xin-N + l) 
x(n-N) 



_xin-L+l) x(n-L) ••• xin-L-N + 2) 



is the L X M input data matrix, and 



h [huh2yh, ...hi] , 



is the filter coefficients vector that represents a combined effect of IF 526 and AAF 532 
along with effects of USB-0 522 and DSB 534. The (Nf + Ng - I) coefficients of the 
combined filter response of IF 526 and AAF 532 may be represented by bi. For example, 
hi may be obtained by convolving// and gi as follows: 



bi = X A Si-k^ 1. for / = 1, 2, Nf+Ng - 1. 

k 

From the combined filter coefficients b/, the elements of h may be easily obtained. 
The effect of USB-O 522 and DSB 534, in one respect, is to select a phase out of possible 
M phases. In other words 

/i/ = ^?M(/ -!)+/?> for/= 1,2, ...,L, 
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where /? % {0,1,2, M - 1 } denotes the selected phase and L may include the smallest 
integer not less than (Nf + Ng- l)/M. Though the exact value of p may not significantly 
impact the performance, an a priori knowledge of p is useful in calculating h. 
The IMS update rule may be defined as follows: 

5 

w„+i = w„-//e(n)X/h, 



irsji;! 



where fi is the IMS step size. The time subscript for Wn may represent the LMS iteration. 
At a first glance, it may appear that the proposed LMS update requires {L+1)N 

10 multiplications per iteration. The factor L may be due to the vector-matrix product X„ h. 
However, due to the shift structure of X„, where Xn is a Hankel matrix, for example, per 
iteration, N multiplications may be required. Hence, the over all computational 
complexity of the LMS for RCDR-EC of the present invention may be 2N multiplications 
per iteration. The multiplication required may be approximately twice that of usual LMS 

15 which in comparison requires only multiplications. Since, there is a saving of filter 
coefficients by a factor M, the computational complexity of the proposed LMS for 
RCDR-EC of the present invention is lower for at least both values of M = 4 or 8. 

A simplified LMS may be used to reduce computational complexities by using an 
approximation on h. 

20 As discussed above, the IF 526 and/or AAF 532 may include low-pass filters. 

Generally speaking, the impulse responses may be similar to the sine function. In other 
words, the impulse response may exhibit a dominant peak and diminish in magnitude 
away from the peak. Moreover, the convolution of the two such filters may also exhibit a 
similar behavior. Other types of filters may be used for IF and/or AAF, in accordance 

25 with the present invention. 

For example, both IF and AAF may include low-pass filters for filtering out the 
high frequency signals above the transmit band. According to one example, the same 
(similar or related) coefficients may be used for both JF and AAF, e.g.,//: = gk for all k. 
For an Annex B application, a 40-tap low pass filter design may be used for at least one 
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10 



of IF and AAF, for example. The impulse response of the 40-tap filter along with the 
time-domain convolution of the two filters are illustrated in FIG.s 6 and 7. FIG.s 6 and 7 
show that the resulting filter after convolution exhibit the properties discussed above. In 
particular, FIG. 6 illustrates an impulse response of IF and AAF. FIG. 7 illustrates a 
convolution of IF and AAF. 

According to an embodiment of the present invention, the largest magnitude 
element of h may be replaced with its sign. Also, the rest of the elements may be set to 
zero. Replacing the largest element with its sign may involve the scaling of h where such 
scaling may be absorbed in fi. Accordingly, there may be little or no approximation 
involved. After such scaling, the remaining elements having a magnitude less than one 
may be approximated to zero. With this approximation the coefficient vector h becomes 
a vector of zeros except one non-zero element (± 1). Without loss of generality, the 
largest magnitude element of h may be assumed to be positive. The matrix-vector 
product may be reduced to a delayed version of the input vector, e.g.. 



15 



An h = 



x{n-d) 
x{n-d-\) 

x{n-d-N + l) 



where h is the approximate h and d is the index of the largest element of h. 
20 Using this approximation, the LMS update may simplify to. 



25 



where x„ is the data vector defined before as 



Xn = [x{n), x(n - 1), x{n -2), x(n - N + 1)] 
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Hence, the simplified LMS update for RCDR-EC is similar to the normal LMS 
update except for the delay. In other words, the computational complexity of the 
simplified LMS for RCDR-EC of the present invention is similar to that of usual LMS. 
5 Since both IF and AAF are part of the system design, the approximation does not 

restrict the use of the simplified LMS. Thus, the IF and AAF may be designed such that 
the resulting combined filter has at least a single dominant coefficient. Factors that may 
severely degrade the convergence and performance of LMS may include multiple 
dominant peaks in the combined filter response and inexact setting of the delay d, 
10 The USB-O 522 with the zero filling structure may be combined with the IF 526 

and efficiently implemented using a poly-phase structure, for example. The same may 
apply for the DSB 534 and AAF 532. 
13 Differences between conventional echo canceller and RCDR-EC of the present 

ru invention may include various factors, such as structural differences, filter lengths, 

}^ 15 computation for LMS training, stead-state computational complexities and noise floor 
''^4 levels, for example. 

As for structural differences, a conventional echo canceller may include an up 

N= sampling block followed by the adaptive FIR ECF that operates at the higher receive rate 

fU 

Li Rrx- In the RCDR-EC approach of the present invention, an adaptive FIR ECF may 

1^ 20 operate at the lower transmit rate Rtx- In addition, a USB and a IF may be used to 
H= generate the echo samples at the receive rate and a DSB and an AAF may be used to 

calculate the error signal at the transmit rate. 

As for filter lengths, to capture the same (or similar) fixed amount of time span 
(e.g., echo tail), the RCDR-EC of the present invention may include N filter taps as 
25 compared to the MN taps required by the conventional echo canceller approach. 
However, in addition to the ECF, RCDR-EC may implement at least two more filters, 
e.g., IF and AAF, for example. In general, the ECF is longer than the combined length of 
IF and AAF and hence, there is a significant reduction in number of filter taps. For 
example, for a typical value of = 256 and M = 8, the conventional filter may require 
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approximately 2048 taps. On the other hand, even with two 64 taps IF and AAF filters, 
the number of taps for RCDR-EC of the present invention is approximately 384, 
substantially less than that required in other systems. 

As for LMS training computation, the computational complexity may be similar 
5 for the conventional LMS and simplified LMS for RCDR-EC of the present invention. 
For example, as the conventional ECF may be M times longer than that of the RCDR-EC 
of the present invention, the number of multiplications required for LMS update may be 
M times higher for a conventional echo canceller. Due to the reduction in the filter taps, 
even the exact LMS for RCDR-EC may have M/2 times lower complexity then the 
10 conventional approach. 

As for steady-state computational complexity, in steady-state using efficient poly- 
phase implementation, for example, the total number of multiplications per second 
associated with RCDR-EC of the present invention may be represented by 

15 {N + Nf + N,)Rt,, 

In contrast, even with efficient poly-phase implementation, the number of 
multiplications per second required by the conventional echo canceller is 

20 NRr^c^ 

In a typical implementation, the total filter length of IF and AAF is less than the 
filter length of ECF, e.g., Nf-^NgK N, As a result, RCDR-EC of the present invention 
may reduce the steady-state computation by at least a factor M. 
25 As for noise floor level and overall performance, in a RCDR-EC system, the AAF 

filters out signals above a transmit band before generating the error signal Thus, the 
error signal reduces the contribution from the wide band receive signal which acts as 
noise for echo cancellers. In a conventional echo canceller, most or all the out of band 
receive signal works to contribute to the error signal. According to the present invention. 
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this reduced noise floor for RCDR-EC results in reduced convergence time and improved 
overall performance of LMS. Other comparisons as well as advantages may be 
recognized by the present invention and variations thereof. 

According to another embodiment of the present invention, a weighted error echo 
5 canceller for transceivers with unequal bandwidths is provided. The present invention 
enables an adaptive echo cancellation filter to perform at a lower sample rate. 

Echo cancellers (EC) may be commonly used in full duplex communication 
systems to suppress the echo of the transmit signal entering the receive path. When the 
transmit and receive path have different bandwidths (hence, different sample rates), the 
10 echo canceller may need to bridge the rate difference. With conventional designs, the 
echo canceller filter operates at the higher sample rate. According to the present 
= , invention, an efficient echo cancellation scheme, referred to as Weighted Vector Error 

O Echo Canceller (WEVE-EC) is proposed for various applications, such as applications 

where the receive path has a higher sampling rate. The WEVE-EC architecture may be 
15 implemented along with an adaptive algorithm, which may be based on Least Mean 
H Square (LMS) update rules. Various other adaptive algorithms may be used to train the 

l^' WEVE-EC of the present invention. 

J;;^ According to an embodiment of the present invention, an error vector, rather than 

M= a scalar error signal, may be implemented for updating the echo canceller. In a 

S 20 conventional approach, essentially all the sampling phases of the error signal are treated 
1=^ as consecutive time samples of a scalar signal at the receive rate. In the proposed 

structure of the present invention, most or all the sampling phases of the error signal may 
be stacked in a vector and treated as a vector sampled at the transnGiit rate. 

An Error Weighting Multi-input-multi-output Filter (EWMF) of the present 
25 invention provides a flexible weighting scheme on most or all the sampling phases of the 
error signal. The Multi-Input Multi-Output (MIMO) filter structure is more general than 
the conventional Linear Time-Invariant (LTI) Finite Impulse Response (FIR) filters. In 
particular, the LTI FIR structure may be considered a special case of the proposed 



-43- 



PATENT 

Attorney Docket No. 56162.000357 



EWMF. Hence, the proposed structure of the present invention provides greater variety 

in selecting a training method for echo cancellers. 

According to another embodiment of the present invention, the combination of an 

adaptive filter and an interpolation filter enables the echo canceller to operate at the lower 
5 transmit sample rate. This is in contrast to the conventional echo canceller approach 

where the echo canceller operates at the higher receive sampling rate. In addition, 

training and updating functionality of the echo canceller may be conducted at the same 

(or similar) low sample rate. 

The architecture of the present invention reduces the number of filter coefficients 
10 without loss of performance. As a result, hardware requirement and computational 

complexities are significantly reduced and an increase in convergence speed of training 

algorithms may be achieved. Other advantages may be observed from the various 

embodiments of the present invention. 

The proposed architecture may be suitable for steady-state tracking of the echo- 
15 canceller. The proposed architecture may also be easily modified for other situations, 

such as the reverse situation where the receive bandwidth is smaller than the transmit 

bandwidth. 

The present invention provides an effective echo cancellation method that takes 
advantage of the situation where the transmit signal, and thus the echo signal generated 

20 from it, has a smaller bandwidth than that of the receive signal. The architecture of the 
present invention may include various components and function blocks, such as an 
Adaptive Echo Cancellation Filter (AECF) 810 which may operate at the lower transmit 
sample rate, an Interpolation Filter Bank (IFB) 820, and an Error Weighting MMO Filter 
(EWMF) 830. Other functions may be implemented in the system of the present 

25 invention. 

A corresponding LMS algorithm of the present invention provides training, 
tracking and/or other purposes. A filter bank design provides an efficient implementation 
for enabling some or all functional blocks to operate at the lower sample rate. Compared 
with the conventional echo cancellation filter which operates at the higher sample rate. 
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the structure of the present invention offers improved performance, while significantly 
reducing the required number of taps, the sample rate, as well as yielding improved 
training behavior and less power consumption. Moreover, the proposed algorithm of the 
present invention also yields better convergence and stability properties during training 
5 and other phases. 

FIG. 8 illustrates a basic signal flow and the functional blocks of the WEVE-EC, 
according to an embodiment of the present invention. The Weighted Vector Error Echo 
Canceller (WEVE-EC) of the present invention may include various functional blocks, 
such as an Adaptive Echo Canceller Filter (AECF) 810; an Interpolation Filter Block 
10 (IFB) 820; an Error Weighting Multi-input-multi-output filter (EWMF) 830; a Reference 
Signal Interpolation Filter (RSIF) 840; and a Vectorization Unit (VU) 850. Other 
y, functional blocks may also be implemented, in accordance with the present invention. 

Q The AECF 810 may include a FIR filter with Nw coefficients and an adaptive 

rU component of the WEVE-EC. The AECF 810 may operate at the lower transmit sample 

2 15 rate. The A/^ coefficients of the AECF may be stacked into a vector w, where 

w [wo, Wi, ... , watw-i]^. 

The coefficient vector w may be adapted during a training period and may be 
Q 20 updated during the steady state. The AECF 810 may receive the transmit signal Xn and 
" generate a copy of the echo signal that is fed to the IFB 820. 

The IFB 820 {/i, ... , /m} may include a fixed filter bank for generating M 
branches of signals from the output of the AECF 810 to match a receive signal vector. 
The branches of signals may be organized into the vector yn = [y«\ . . . , yn^f at each time 
25 instance or other time interval. For example, an integer M may be used where the 
architecture of the present invention may be easily modified with a scheme, such as a 
mixed upsample-downsample scheme, to accommodate various rational values of M. 
The output of the IFB 820 may include a vector signal y) which may be obtained by 
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filtering the output of the AECF 810. This signal may be used to generate the residual 
echo Fn. 

The weighted error vector represents the training error of the adaptive echo 
canceller filter. The EWMF 830 H allows a flexible weighting on the error vectors and 
5 thus offers a vast set of options for advanced training of the WEVE-EC of the present 
invention. 

The RSIF 840 may include a fixed filter for generating a reference signal for 
training and/or other purposes. The filtering operation may involve a combination of the 
IFB 820 and the EWMF 830, for example. 
10 The transmit signal x„ may occupy a different (e.g., smaller) bandwidth than that 

of the receive signal. The filtered transmit signal 4i i^ay be obtained by filtering the 
transmit signal The signal x„ may then be used to generate the reference signal 

The reference signal 5 j may be obtained by filtering 4^ The reference signal may 
be used for the LMS algorithm during the training of the AECF 810 with coefficient 
15 vector w. 

The receive signal vector may be represented as 

20 This receive signal vector may be obtained by stacking the M sampling phases of 

the receive signal into a M length vector. The receive path may provide a sample rate M 
times higher than the transmit path. Hence, the vectorized receive signal dn has a 
sampling rate equal (or similar) to the transmit sampling rate. 

The VU 850 may include sub blocks, such as Delay Units zQ^ and Down 

25 Sampling blocks. Other sub blocks may also be incorporated by VU 850. The Delay 
Units sub block as designated by z(A:) may delay a signal by K samples. The Down 
Sampling blocks as designated by M and a down arrow may be used to drop M - 1 
intermediate samples from the input signal. In other words, Down Sampling block 
decimates the input samples by a factor M. 
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The residual echo vector r„ = d„ - y« may be obtained by subtracting the output of 
the IFB 820 from the receive signal. During the training period, the residual echo vector 
Tn may be used to generate the weighted error vector e„ for the LMS update or other 
purpose. The weighted error vector e„ may include the filtered residual echo vectors and 
5 may be used for training purposes, e.g., to train the AECF 810. Once the WAVE-EC is 
properly trained, e^^ may contain a small portion of the echo signal. 

hi the steady state, operational function blocks may be limited to the AECF 810, 
the IFB 820, and the VU 850. The RSIF 840 and the EWMF 830 may be implemented 
for training/tracking purpose. The signals for steady state operation may include the 
10 echo-canceller output yj" and the echo cancelled signal r/. The signals Sk and et may be 
generated for the adaptive LMS. 

Various echo canceller parameters for the architecture of the present invention as 
well as the LMS algorithm may be implemented as described in detail below. 

Integer M may include the ratio of the receive sample rate to the transmit sample 
15 rate. M> I implies that the transmit sample rate is lower than the receive sample rate. 
According to the present invention, the IFB 820 may be used on the transmit signal and a 
branching operation on the receive signal to bridge the transmit path and the receive path. 

Adaptive Echo Canceller Filter 810 length iVw may represent the number of taps in 
filter 810. As the architecture of the present invention may operate at a lower sample 
20 rate, the length is substantially lower than that of an echo cancellation filter operating at a 
higher sample rate. 

EWMF coefficients may be grouped into a matrix, such as {hm^n; m = 1, M, n 
= 1, Nh}. The choice of the coefficients may depend on the nature of the transmit 
signal, receive signal, and/or the echo signal, as well as, the training algorithm used to 
25 train the echo canceller. Other factors may also be involved in the choice of coefficients. 

The dimension of the EWMF matrix may be represented as M x iVn. For LMS 
algorithms, Nh may be a multiple of M, e.g., K = Nh/M is an integer. K may represent the 
number of residual echo vectors that are used to generate the weighted error vector. A 
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larger EWMF matrix permits a more flexible weighting scheme on the error signal at the 
cost of higher complexity. 

Interpolation Filter Bank (IFB) coefficients may be represented by {fn^^\ 
M, n = 0, , . . jN^ - 1 } : A dedicated filter of length Nf may exist for each of the M signal 

5 branches. These coefficients may be chosen such that a desired interpolation filtering 
performance is achieved with a given filter length. 

Interpolation Filter Bank length may be represented by Nf, The length may be 
decided by a desired performance of the up sampling block, the computational cost 
and/or other factors. The performance as well as the complexity may increase with the 

10 length of the filter. 

LMS update step size sequence may be represented by fin* Generally, the larger 
the step size, the faster the training will converge. However, there may be a limit on the 
magnitude of the step size. For example, a large enough value may cause the training 
algorithm to diverge. On the other hand, the smaller the value of jUn, the smaller the error 

15 floor. For example, the step size sequence may be chosen as constant or as a decreasing 
set of numbers such that the algorithm quickly achieves convergence with large step sizes 
at the early stages of the training procedure and obtains low error floor with smaller step 
sizes later in the training procedure. This is commonly known as a gear shifting method. 
The training procedure of the present invention may involve adapting the 

20 coefficients of the echo canceller filter based on up-sampled reference sequences and/or 
weighted error signal. Other factors may be considered. The adaptive echo canceller 
may be matched to the echo path such that a significant component of the echo 
component in the receive signal may be cancelled. The effectiveness of the echo 
cancellation may be measured by the energy of the weighted error signal. The tracking 

25 procedure may use the same (similar or related) update mechanism as that of the training 
procedure or a variation thereof. 

The training method is not limited to the LMS algorithm as discussed above, but 
other algorithms may be used instead of LMS, in accordance with the present invention. 
The scalar form of an LMS update rule may be described as follows: 
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irs ii 



Is: 



where Wn is the adaptive entity for the LMS algorithm, e„ is an error signal, n is 
5 the time index, and fin is the LMS step size. The update rule for the proposed LMS 
algorithm is shown below in step 918. Compared with the scalar form, the proposed 
update rule of the present invention provides a more flexible weighting scheme for the 
error signal. 

In the proposed LMS algorithm, each update may involve the steps of FIG. 9. At 
10 step 910, a vector corresponding to a reference filter may be formed. At step 912, a 
matrix may be formed. At step 914, a weighted error vector may be formed. At step 916, 
an adaptive echo canceller filter may be updated. At step 918, the weighted error signal 
energy may be calculated. The steps of FIG. 9 will be described in detail below. 

At step 910, vectors ... , corresponding to reference filter may be formed 

15 where 

At step 912, the matrix may be formed as follows: 

20 

Sn = [ Sfl T Sn ]. 

At Step 914, weighted error vector may be formed as follows: 
25 e„ = [e„> e„2 t e/f. 

At step 916, the adaptive echo canceller filter may be updated as follows: 

w„+i =w„+;i„Sne„. 
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At step 918, the weighted error signal energy e/e„ may be calculated. At step 
920, it may be determined whether the energy is less than a predetermined value. If so, 
the process may be terminated at step 922. If the energy level is equal to or above a 
predetermined value, then n = n + 1 and a feedback loop to step 910 may be established. 

The present invention also provides advantages with respect to computational 
complexity. For example, it may take Mv + MNf + MNh multiplications to generate the 
weighted error vector en, MNf + MNh multiplications to form the matrix Sn, and M Ny, 
multiplications to execute the update equation for each update of the AECF. In total, (1 + 
M^)Ny, + 2M{Nf +Nh) multiplications may be required for each update of the AECF. 

Additional details of the LMS algorithm of the present invention will now be 
described. The output of the echo canceller interpolation filter bank (e.g., IFB 820) 

r 1 t 
y« = l>n J . J« ] » 

may be written as 

yn = FX„Wn 

where F represents the echo canceller Interpolation Filter Bank, e.g., 



F = 


' f (I) 

^0 

Jo 




JNf-l 

JNf~i 




Jo 




f (M) 
JNf~\_ 



and 
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X„ 



\-Nf+\ 



'^n-Nf-Nw+2_ 



is the transmit signal matrix. 

In one example, the filter bank F may implement a zero-insertion plus low-pass 
filtering operation. In such cases, F may be written as 



F = 



fo 


Im 


f(Nf-\)M 


/, 




f(Nf-\)M+l 


/m-1 


flM-l 


Injm-x 



where |/o, • • • jNfM-if may be a iVykf-length low-pass filter. 

As the receive signal may occupy a larger bandwidth than that of the transmit 
signal, the residual echo vector may have a significant out-of-band noise. This out-of- 
band noise has detrimental effect on the adaptation process and should be removed. 

According to an embodiment of the present invention, the out-of-band noise may be 
removed or minimized by passing the residual echo vector through the EWMF, or other 
filter. As discussed above, the residual echo signal may be represented by 

r„ = d„ - y;,. 

Using the residual echo signal, the weighted error vector may be written as 
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= H 














n 







In the formulation, K = Nh/M residual echo vectors may be involved in the 
filtering operation to generate a filtered error vector. By using the matrix 



H = 



to represent the weighting operation, the possibility of using different filters for each 
10 sampling phase is preserved. For the special case where a single K tap FIR filter is used 
for all sampling phase, the H may become a Toeplitz matrix with the first row 

M-l zeros M-l zeros M-l zeros 

where the K non zeros elements [hu . . Jik] may be defined as the FIR filter coefficients. 
A Toeplitz matrix generally refers to a matrix whose entries are constant along each 
15 diagonal. 

After defining the necessary signals, the corresponding Least Mean Square (LMS) 
algorithm for the coefficients of the echo cancellation filter may be derived in accordance 
with the present invention. For example, the instant gradient for the LMS training 
algorithm may be obtained by taking the derivative of t^J^n with respect to w. The 
20 update rule may then be represented as: 



w„+i = w„ ■ 



2 aw„ 
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= W„ + tin [Xn^F'' I t I X^n-K+lF^] ' ' e„. 

The matrix multiplication in the update rule may represent the operations 
5 performed in the reference signal interpolation filter (e.g., 840) in FIG. 8. 



[X„V|...|XVk+iF']-H 



10 



M 



9«-2 



^n-K+l 



M 



M 



where the filtered output sj may be arranged into a matrix. The final form of the update 
15 rule may be represented as 



According to another embodiment of the present invention, a minimum mean 
square error linearly constrained fast algoriAm for adaptive training of a Time Domain 
20 Equalizer (MLC-TEQ) is provided. A fast adaptive algorithm of the present invention 
may be used to obtain Finite Impulse Response (FIR) filter coefficients for Time domain 
Equalizer (TEQ) used in Discrete Multitone (DMT) based applications, such as ADSL, 
for example. The TEQ coefficients obtained by the algorithm of the present invention 
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shortens the overall effective discrete time channel impulse response length within a 
given target length (e.g., symbol prefix length for DMT application). Advantages of the 
proposed data aided adaptive algorithm may include providing the TEQ filter coefficients 
with near-optimal performance; having low computational requirements, having fast 
5 convergence, and exhibiting attractive stability properties. Other advantages may also be 
realized by the present invention and variations thereof 

Other features of the algorithm of the present invention may include 
implementing a Target Impulse Response (TIR) vector, e.g., the combined response of 
the transmission channel and TEQ filter, as a search vector, e.g., the vector that needs to 
10 be calculated. 

The algorithm of the present invention may constrain a selected element of the 
TIR vector to be approximately equal to a constant where the selected element may be 
f5 any element of the TIR vector. The error may be computed by using the difference 

Ej between the TEQ output and TIR filter output. TEQ filter coefficients may be adaptively 

Q 15 computed by minimizing the Mean Square Error (MSE) criterion. TEQ filter obtained 
n through the algorithm of the present invention may provide minimal energy Inter Symbol 

W Interference (ISI) and Inter Channel Interference (ICI). 

The computation requirement of the algorithm of the present invention may be 
linear in equalizer length, e.g., the number of filter taps of the equalizer. As a result, the 
CO 20 algorithm is suitable for practical implementation in various applications. The algorithm 
5; J of the present invention may adaptively calculate an equalization delay using the training 

and received sequences thereby providing efficient use of FIR TEQ filter coefficients. 
The algorithm of the present invention may incorporate input data conditioning through 
use of dummy signals thereby providing enhanced stability and improved convergence. 
25 The present invention provides a fast, stable and high performance adaptive 

algorithm for computation of near-optimal FIR TEQ coefficients. The resulting TEQ 
filter shortens the overall channel response such that residual energy of the overall 
channel outside the target length is minimized. In applications, such as DMT, TEQ 
filters obtained through the algorithm of the present invention provides minimum energy 
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Inter Symbol Interference (ISI) and Inter Channel (or Carrier) Interference (ICI) and as a 
result yields a higher bit rate. Other advantages may also be recognized. 

In Discrete Multitone (DMT) systems, it may be desirable for the discrete time 
channel spread to be less than a prefix length to avoid ISI and ICI. Jn some applications, 

5 the spread of the channel may be greater than the prefix length. Hence, preprocessing of 
data may be implemented to shorten the effective channel seen by the DMT receiver. An 
approach, e.g., Time domain Equalization (TEQ), may be implemented to apply (sample 
or fractionally spaced) Unear filtering to the sampled receive data to shorten the effective 
channel spread. The present invention provides an approach to designing sample spaced 

10 and fractionally spaced (e.g., with factor 2 or other factor) Finite Impulse Response (FIR) 
TEQ filters. 

FIG. 10a outlines a basic setup for a TEQ system, according to an embodiment of 
the present invention. Here, Xk represents the k-th sample of the transmitted signal with 
variance (^x^ Block 1010 with up-arrow and M corresponds to an up-sampling function 
15 with factor M, which may involve inserting M - 1 zeros between the samples of x^. For 
example, for M = 2 case, 4 sequence may be given by 

^, 0, X_2, 0, X.U 0, Xo, 0, Xu 0, X2, 0, X3, 0, «- 

20 For example, M = I may refer to a sample spaced TEQ, as represented in Fig. 

10b, and M=2 may refer to a fractionally spaced TEQ. 

The combined effects of the transmit filter shaping, the receiver filter, and the 

distortion caused by the transmission channel may be modeled by a Linear Time 

Invariant (LTI) system, as illustrated by 1012, with impulse response denoted by Ajt. The 
25 combined effects of the receiver noise and the interferences may be modeled by the 

additive disturbance v^^ 

In FIG. 10a, block 1014 represents a TEQ filter having Nteq filter coefficients. 

Nteq TEQ coefficients may be denoted by {wi, W2, wmteq) and TEQ coefficient 

vector may be denoted by w, e.g.. 
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W=[Wi<r- WnTEQ ] 



An output of the TEQ filter 1014 may be down-sampled where the down 
sampling process is represented by a block 1016 with down-arrow and M. The down- 
sampling operation may involve selecting 1 out of M samples of Ok. For example, for M 
= 2 case, Zk sequence may include 



The time domain equalization may convert the channel impulse response hk into 
an impulse response with Nt nonzero consecutive entries. Therefore, if the nonzero 
entries of the resulting channel are modeled with the sequence {b{c\ kx {0 ^r- Nt- l}},thc 
target channel may be modeled as 



where d is the effective delay corresponding to the starting location of the non-zero 
segment of the impulse response. 

In DMT based DSL systems, such as G.dmt and G.lite, standard generally 
dedicates certain training sequences for the computation of TEQ coefficients. These 
training sequences may be periodic DMT symbols without prefix where the period is one 
symbol long, for example. According to one example, n % {0, <^ , Nr - I}} may 
represent the DMT symbol of length Nr, where the transmitted training sequence rn 
represents the repeated version of e.g.. 



<-<?.2» OOy 02, O4, <- 




'n-d 



d<n<d^Nj-\ 
otherwise^ 



and m = mod{n, Nr) 
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where mod(n, Nr) is the remainder of h/Nr and hence, m is an integer between 0 
andNR- 1. 

Therefore, r« may represent a periodic extension of the sequence e.g., r„ may 
5 be obtained through periodic repetition of pn where the period is Nr. The periodic 
extension may be expressed as 

Pnr-2, Pnr-u Po, Pu Ply ^ > Pnr-u Po, Pu <r- 

10 An adaptive TEQ problem may involve developing an algorithm that processes 

training signal r„ and corresponding received signal yn to obtain TEQ filter coefficients 
without any a priori knowledge of channel and noise statistics. 

For DMT applications, an optimal approach may involve choosing {wjc} such that 
the number of bits loaded per symbol may be maximized. However, this approach may 

15 be difficult to implement and impractical for adaptive implementations. Other alternative 
schemes either have high computational complexity and are therefore not suitable for 
adaptive implementations or have lower complexity but low performance and instability 
in the convergence. The present invention provides an adaptive approach that yields 
enhanced (or near-optimal) performance. 

20 MLC-FAST-TEQ algorithm of the present invention uses training data sequence 

{r«}, and the corresponding received data sequence {yn}. Exemplary special cases for the 
algorithm may include a Sample Spaced Case where M = 1 and a Fractionally Spaced 
Case with factor 2 where M = 2. In the Fractionally Spaced Case, {yen} and {yon} may 
represent even and odd phases of the received sequence respectively, e.g.. 



25 



yen = yin 

yon = y2n+h 

where yn is the over-sampled received sequence. 
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In this section, various algorithm parameters, which may include predetermined 
constants independent of the data, may be used in the algorithm of the present invention. 
Their values may be adjusted to achieve different levels of performance and stability as 
well as other results. 

5 The algorithm may assume certain conditions about the amount of training 

sequence data required, e.g., the length of the training sequence Ntr* For example, the 
training sequence may involve consecutive samples of the received signal n % {0, ... , 
Ntr ' 1 } } for the sample spaced case. In another example, the training sequence may 
involve consecutive samples of the sequences {yen, n % {0, ... , Mr - 1 } } and {yon\ n % {0, 

10 ... , iVfr - 1 } } for the fractionally spaced case. 

Parameters used in the algorithm of the present invention include: Nt which 
represents target channel length; Nteq which represents TEQ filter length; Nr which 
represents symbol length; L which represents fixed tap location where L % (0, ... , A^r - 1 }; 
Ns which represents TEQ algorithm search vector size Ns = Nt + Nteq\ ® which 

15 represents least square cost function forgetting factor; Nd which represents maximum 
tone number for the dummy signal and N-^ which represents number of update variables 
where 



20 Ny = 



3 Sampled SpacedCase 

4 FractionallySpacedCaseWithFactorl, 



Other parameters may include {Ck\ k % {0, <^ , Nd - I}] which represents 
frequency domain dununy signal values. There are No such complex values, e.g., Q may 
be complex numbers. Other parameters may include {©„} which represents time domain 
25 dummy signal, which may be determined by the frequency domain dunrniy signal values. 
The following equation shows the relation: 



"58- 



PATENT 

Attorney Docket No. 56162.000357 



®n = Co + X2 Real part of {C^^^^} nx {0,'^ , Nr- 1}. 

where the term Real part of stands for the real part of a complex number. The time 
domain dummy signal may be defined as the repeated version of ©n, e.g., {®n = ®m }, 
where m = mod{n, Nr). In other words, ©n may represent the periodic extension of the 
signal ©n. 

Other parameters may include S which represents the scahng of the received 
dummy signal; c?r which represents hitemal dynamic range arrangement parameter; and 
ca which represents a priori variance constant used for the initialization of the matrix F. 

The MLC-FAST-TEQ algorithm of the present invention includes at least two 
steps, which may include the adaptive computation of the equalization delay parameter d 
and the adaptive computation of the TEQ filter coefficients based on the delay d 
calculated in the first step. 

An estimate of cross-correlation function {q(k); k x {0, <r- , M x Nr - 1}} may be 
computed as 

1=0 n=0 

where NuvMNr < Ntr> 

Then ® may be defined as the argument maximizing the absolute value of the 
cross-correlation function: 

® = argmaxk \q{k)\ 

Therefore, ® represents the peak point location for the absolute cross-correlation 
function. 
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An equalization delay d may be selected as a function of ®. An appropriate 
choice of d may be given by: 



d=l/M{ ®+Nteq/2}. 

In other words, 



d = 



N 

k: + — ^ Sampled SpacedCase 

K N 

— + FractionallySpacedCase 



Adaptive computation of TEQ coefficients for a sample spaced case includes 
algorithm variables such as the following: 
: Column Vector (Size N^ x L); 
(D : Column Vector (Size N^^ x L); 
? : Column Vector (Size N^^ x L); 
® : Column Vector (Size N^^ x 1.); 
«^ : Column Vector (Size N,^ x 1.); 
A : Matrix (Size N^ x Ns), initialized to all zeros; 
D : Matrix (Size x Ns), initialized to all zeros; 
X : Column Vector (Size Ns x 1), initialized to all zeros; 
k : Column Vector (Size Ns x 1), initialized to all zeros; 

F : Matrix (Size N^^ x N^^), initialized to gsInx^ where In^ stands for identity matrix 
of size N), X N^^; 

t : Column Vector (Size N^^ x 1), initialized to all zeros; 
b : Column Vector (Size Ns x 1), initialized to all zeros; 
m : Column Vector (Size Ns x 1); 
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(D : Column Vector (Size N,^ x 1); 
c : Column Vector (Size Ns x 1), initialized to all zeros; 
X : Scalar; 
e : Scalar; and 
5 n : Scalar. 



10 



TEQ coefficient algorithm steps include the following: 
step 1. n = 0, 



step 2. 



step 3. 



(D = 



'n-d 



'n-d-L-\ 



n-d 



d-L-\ 



X 



15 



step 4. 
step 5. 
step 6. 
step 7. 

step 8. 

step 9. 
step 10. 
step 11. 



= (D + AX, 
A = A - k^'^, 
? = ^(l-k'^XX 
F = ®F, 

/ ^ 

G 



t = F 



a 



F = F-t(/i>^T), 
t = c«F^, 
b = k + At, 
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step 12. 



step 13. 



step 14. 



m = 



(D^ = [bNTEQ 



bNTEQ+I^l ^Ns], 



x= 



la 



step 15. 




®+DX, 




step 16. 


k = 






step 17. 


D = 


D - k^^, 




step 18. 


X = 






step 19. 


e = fn-d-L-l + ® 


n-d-I^l - X , 


step 20. 


c = c + ke. 




step 21. 


n = n+ 1, 




step 22. 


if n< Ntrthen go to step 2, else stop. 



TEQ coefficients may be given by the first Nteq taps of the vector c, e.g., 

W = CiNTEQ 

Adaptive computation of TEQ coefficients for a fractionally spaced case with 
Factor 2 (e.g., M=2) may include variables that are identical (or similar) to that for the 
sampled spaced case, discussed above. The steps for the algorithm may include the 
following: 

step 1. n = 0. 
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step 2. 



step 3. 

step 4. 
step 5. 
step 6. 
step 7. 

step 8. 

step 9. 
step 10. 
step 11. 



step 12. 



yon 



"TEQ 



? = ® +AX, 
A = A - k^^, 

r=/i>.(i-k^x), 

F = ©F, 
f 

e 



t = F 



1 T 



a 



F = F - iifb-^Y), 
t = oarF? 
b = k + At, 



m = 



iNrEQ-2) 



Step 13. 



®^ = [bNTEQ 



bNTEQ+L-l bNs]» 
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I. 



X 



step 14. 



1 C^ree-Z) 
X= ^3 



step 15. 






step 16. 






step 17. 


D = D - k V, 




step 18. 


Jc = c^X, 




step 19. 


e = + © 


[i-d-)>l - X , 


step 20. 


c = c +ke. 




step 21. 


n = n+ 1, 




step 22. 


if n< Ntr then go to step 2, else stop. 


TEQ coefficients are given by the first Nteq taps of the vector c, e.g. 




W = Ci:NTEQ 





Further to the adaptive manner of obtaining FIR coefficients in a TEQ filter 
15 described above, we now turn to a method and system for shortening the channel impulse 
response in DMT systems wherein a model is employed to effectively represent a 
hypothetical delay transmit signal in conjunction with a desired shortened channel 
impulse response filter to arrive at near optimal TEQ coefficients. In contrast to the 
adaptive process described above, where the TEQ setup involved a fractionally spaced 
20 TEQ scenario in which up-sampling/down-sampling factor M = 2, as shown in Fig. 10a, 
the TEQ filter solution described in this section is based on a sample spaced TEQ setup in 
which M = 1, as shown in Fig. 10b. 
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In DMT systems, each received data symbol or packet is commonly prepended 
with a guard sequence called the cyclic prefix that is used to space the symbols so that the 
receiving system recognizes each individual packet of data. Each DMT symbol typically 
consists of N samples (where N is an arbitrary integer), while the cyclic prefix is a copy 
5 of the last v (where v is an integer less than N) samples of the DMT symbol In order to 
prevent ISI, the value of v must be greater than or equal to the length of the channel 
impulse response, i.e, the channel length, commonly denoted by the variable k 

Upon receipt of the symbol by the receiving modem, the cyclic prefix is 
discarded, since it includes no information not otherwise included within the symbol. 
10 The symbol is further processed, and conventional methods of shortening the channel 
impulse response are applied. Because the cyclic prefix does not convey any new 
information about the transmitted signal, efficiency of the system decreases in proportion 
5 to N/(N+v). Therefore, in order to maximize system efficiency, either N should be large, 

or V should be small. However, as N increases, memory requirements in the 
15 communications system are also increased. 

^ In DMT systems, it is further desirable that the discrete time channel spread is 

less than the prefix length so as to avoid ISI as well as ICI, which is the convolution of 
i'r signals on overlapping carrier channels. In applied systems, the spread of the channel is 

;i typically significantly greater than the prefix length. Therefore, preprocessing of data is 

C3 20 required to shorten the effective channel seen by the DMT receiver, thereby reducing the 
occurrence of ISI and ICI. The most common approach to this preprocessing function is 
to apply Time Domain Equalization (TEQ) to the sampled receive data to shorten the 
effective channel spread. TEQ refers to a process for filtering the incoming signal in 
such a way as to combine the data signals from various channels and reduce the cyclic 
25 prefix of the resulting signal to a uniform size that is as small as possible. 

FIG. 10b illustrates the basic scenario involving the above described TEQ 
problem. In particular, Xk (where A: is an integer) 1000 denotes the transmitted signal that 
is propagated along a channel and ultimately received by a modem. The transmitted 
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signal includes, for instance, v+1 input samples. The effects resulting from the 
transmission channel are modeled and represented by the h channel block 1012, where 
the resultant, hk, denotes the original "long" channel impulse response. A: is a whole 
number from 1 to At, where Nc is the channel impulse response length of the channel h. 
5 The resultant signal hk is further distorted by additive disturbance Vk (where A: is a real 
number), which models the receiver noise and other signal interferences. This effect is 
represented, for purposes of illustration, by the combination of h and v^^ at hypothetical 
adder 1002. The resultant is the combined, unfiltered signal yt that represents the signal 
as input at the receiver device, for instance a modem. The signal yk is received at the 
10 TEQ filter 1014 for preprocessing as described further below. The signal y^ is the 
resultant vector of the current and previous received samples, Nw, and is passed through 
TEQ filter 1014, which operates to shorten the channel impulse response of yk and results 

Q in output signal vector Zk 1004. The TEQ vector >v^ to be applied to the signal yj^may be 

calculated using TEQ filter coefficients {wk}, and vice- versa, and is combined with the 

H 15 signal yk to produce the filtered output signal Zk 1004 having a shortened channel impulse 

'J response. 

2 Initially, the transmitted signal, Xk 1000, is assumed to be an uncorrected and 

f[| identically distributed wide sense stationary sequence having a zero mean and a squared 

^ variance ofxk, Ox^. It should be understood that this assumption is not entirely accurate in 

C3 20 that the existence of the cyclic prefix, which is the simple repetition of a portion of the 
" transmitted samples, causes some degree of correlation among the samples. However, 

generally, the separation between the repeated samples is large enough to neglect the 

correlation due to the prefix. 

Accordingly, the combined effects of the transmission filter, the receiver filter, 
25 and the distortion caused by the transmission channel are modeled by a linear time 
invariant system with the impulse response hk. As briefly described above, the receiver 
noise and other interferences are modeled by additive disturbance Vk, which is assumed to 
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be a wide sense stationary sequence having a zero mean and correlation coefficients 
represented by: 

/V(m) = E{vi,vl+J 
where m is a real number and where is the noise autocorrelation sequence. 

5 In one manner, the TEQ filter vector w'^ is calculated using a number (designated 

as Nteq) of Finite Impulse Response (FIR) TEQ filter coefficients {w^}, where the 
coefficients are defined as: 

{Wk-M{ 1... ^teq)} 

and 

M 10 W = [Wi<r- WnTEQ f 

O A goal of TEQ is to convert the channel impulse response hk into a target impulse 

|:3 response with effectively only a certain number of nonzero entries, designated as 

;1 Therefore, if the nonzero entries of the resulting channel are modeled with the sequence 

fy bk, where A: is a whole number from 0 to Np-1 , the target channel, tn, can be formulated as: 



15 



1 0 otherwise, I 



where d is the effective delay corresponding to the starting location of the non-zero 
segment of the impulse response. 

For TEQ filtering in a DMT system, one optimal approach involves selecting 
[wk] such that the number of bits loaded per symbol, B, is maximized. This approach is 
20 equivalent to maximizing B as: 
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where T is the set of transmit tones, 5,(w) is the desired signal energy at tone /, /,(w) is the 
combined energy of ISI and ICI at tone / caused by the components of r„ outside <i < n < 
d+N-rh N,{yv) is the noise energy at tone /, and T is the effective gap which is a function 
of the constellation, coding gain, and the margin requirement. 

5 Unfortunately, the maximization of B with respect to w is a difficult, processor 

intensive computation, and is impractical for most real world, adaptive implementations. 
Therefore, some altemative near-optimal schemes have been developed. One such 
scheme includes maximizing the geometric Signal to Noise Ratio (SNRo) as: 

10 SNRg can be defined as the product of SNRs at each transmitted tone within the symbol. 
However, this process is also computationally complex and, consequently, is also 
unsuitable for practical applications. Altemative, comparatively lower complexity 
approaches such as that described in United States Patent No. 5,285,474, to Chow et al. 
have been developed. However, the reduction in computational complexity is achieved at 

15 an unacceptable cost of significant performance degradation or convergence instability in 
most real world applications. 

An altemative solution to the TEQ problem includes minimizing wall energy with 
a constant constraint on the power of the target impulse response which leads to a 
computationally demanding Singular Value Decomposition (SVD) based algorithm. 
20 Wall energy is defined as the residual impulse response energy outside of the region 
corresponding to the target impulse response. One manner explored for enabling such 
wall energy minimization includes utilizing a least square fit based approximation. 
Unfortunately, this solution has proven to result in unacceptable levels of performance 
degradation. 

25 An alternative solution to the above problem includes a conventional Minimum 

Mean Square Error (MMSE) approach, where the target impulse response (TIR) 
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coefficients are assumed to be part of the desired final, filtered signal vector (the search 
vector). However, the squared norm constraint assumed in this approach to avoid an all- 
zeros solution leads to numerically difficult computations, such as an eigenvector 
computation to obtain TEQ coefficients. It is especially hard to implement direct 
5 adaptive training of the equalizer coefficients under this constraint. 

While theoretically it may be possible to achieve improved performance using a 
significantly longer TEQ filter, the computation needs, power and silicon area required to 
implement such a long TEQ filter arrangement is not likely cost effective and largely 
impractical. Further, in practical applications, adaptive computation of TEQ filter 
10 coefficients is a necessity. Still further, most digital signal processors (DSPs) in practical 
applications support only fixed point arithmetic. As a result, finding stable adaptive 

U algorithms with fixed point arithmetic to compute long TEQ filters may not be practical. 

S Therefore, there is a need in the art of digital conmiunication systems for a practical 

method and system for effectively and efficiently shortening the channel impulse 

|I 15 response ^jk to a filtered channel impulse response Zk- 

fC The present invention overcomes the problems noted above, and provides 

L. additional advantages, by providing for a method of applying linear filtering to the 

lU received data set. The filtering is achieved by factoring the transmit data {Xk) along a 

m channel Qik) combined with additive disturbance/noise consideration (vfc) to arrive at a 

^ 20 combined unfiltered signal (yO, and in consideration of a hypothetical sampling of the 
transmit data along a delay channel (d) to arrive at a target impulse response. From this, 
the present invention derives a Minimum Mean Square Linearly Constrained Time Delay 
Equalization (MLC-TEQ) mathematical model and applies the target impulse response to 
achieve a shortened channel impulse response (zO- The shortened channel impulse 
25 response defined by processing the unfiltered received data (yk) through the TEQ 
coefficients and TEQ vector is effectively compared with the hypothetical target 
channel impulse response which is derived from the delay channel as applied to (bkX 
to determine an error ek which is to be minimized by design. In this manner, the received 
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data signal (yk) is converted into a TEQ filtered signal (Zk) designed to approximate a 
desired target channel (r„). The invention shortens the overall channel response in a 
communication system such that the residual energy of the overall channel outside the 
target length is minimized. In addition, Inter Symbol Interference is minimized by the 
5 present invention. 

The block diagram of FIG. 10c illustrates the inventive MLC-TEQ filter approach 
that overcomes the shortcomings of earlier approaches and yields the aforementioned 
advantages. In particular, a transmit data signal, Xk 1000 is propagated along a channel 
1012 having distortive effects on the signal, as represented by the h channel block 1012, 
10 and has an effective channel impulse response represented as hk at 1020. To more fully 
represent the effects of various processes on the transmit signal, a disturbance vector vj,, 
which models the various receiver noises and interferences, at 1022 is applied to the 
O channel impulse response to yield an unfiltered received data signal yk at 1024 that is 

(5 received at an input of the TEQ filter 1014. By way of example, the received data signal 

H 15 yk could represent the input of a modem commonly used in communication systems. 
H Unfiltered signal 3;^ is the resultant vector of the current and previous Nw received 

r samples, where Nw is defined as an integer representing the number of replicate received 

r: samples of transmitted data and represents TEQ length. 

;^ j: The unfiltered yk signal is passed through Time Domain Equalization (TEQ) filter 

C3 20 1014, which shortens the channel impulse response and generates a shortened channel 
" impulse response signal Zk at 1026. As shown by the hatched lines, a hypothetical parallel 

branch of the transmitted data signal is shown as a delay function (d) 1032 applied to a 
determined target vector bk to yield a target channel tn for modeling the shortened channel 
impulse response to arrive at the TEQ filter coefficients, hi effect, the TEQ filter 1014 
25 shortens the channel impulse response to minimize the mean square error ek, E{ek ), 
between the received signal and the hypothetical delay channel, thereby approximating 
the desired target channel. 
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As shown in Fig. 10c, hypothetically, the delay channel 1032 generates a signal at 
1034 having a Target Impulse Response b 1036. The delay channel 1032 output is acted 
on by TIR b vector 1036 to produce the target impulse response channel tn is, in a sense, 
compared with the TEQ filter output vector Zk 1026 resulting in a data error signal ek at 
1004, which represents the kxh error signal (that is, the error signal that corresponds to the 
resultant data signal). In determining the desired TEQ filter coefficients, ek is minimized. 

In order to minimize the minimum mean least square error between the parallel 
communication channels (i.e., the impulse channel and the delay channel), it is necessary 
to calculate the TEQ filter coefficients used in generating the Equalizer Coefficient 
Vector v/ such that the resultant vector has minimum energy Inter Symbol Interference 
(ISI) and Inter Channel Interference (ICI). 

The MLC-TEQ approach of the present invention provides a family of solutions 
that are parameterized by variables d g {0,..., Nc + Nteq - //r - 2} and L g {0,..., Nt - 
1}. It is further assumed that the channel impulse response {K i e {0,..,, iVc - 1}} and 
the noise autocorrelation sequence {ry(i\ i e Z} are known or estimated. Each solution 
has a closed form expression in terms oid,L,{hijG^ {0,..., A^c - 1 ) }, {'*v(0» ^ ^ Z}, TEQ 
length Nteq and the target impulse response length Nt. For fixed values of d and L, the 
MLC-TEQ filter determination steps are discussed in more detail below. 

The approach embraced by the TEQ filter determination process of the present 
invention poses the TEQ problem as one of minimizing the error differentiating the 
parallel branches of the h channel 1012 and hypothetical d channel 1032 of Fig. 10c to 

determine the desired TEQ coefficients {wk}. represented as: 

{Wk\k^[\ Nteq }} 

and Target Impulse Response coefficients {Ztr} as: 

{i>k;kG{l,...,A^r}}. 
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An additional constraint on w or b is used to avoid the trivial all zeros solution. In 
the present invention, that constraint is preferably on b, where one of the taps of b is 
constrained to be equal to a non-zero constant as bi = c, where L e { l...iVr}. c e9l, and c 
96 0. C may be chosen as c = 1 without a loss of generality. This constraint allows the 
use of linear mean square minimization techniques, and the resulting algorithm is 
therefore more suitable for fast and efficient direct adaptive implementations. 

Due to the disturbance Vk and the finite length constraint on b and the error 
sequence {ek} has been found to generally not be equal to zero. Therefore, the error may 
be minimized in order to create effective filtering. In one manner, the mathematical 
method of the present invention, targets the minimization of the mean square of error e^. 
In order to do so, the TEQ problem is preferably posed as to minimize E{ek) for w and b 
such that bi^l, where: 



... 1%^ 



and 



E{el) 



is the expected value (mean) of the square error, which is the minimization of mean 
square error by choosing vector variables w and b under the constraint that the Lth tap of 
vector b is constrained to be equal to 1. Minimization of E over w and the unconstrained 
components of ft is a linear mean square minimization problem and the result for TEQ 

coefficient vector w is given as: 
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Referring now to the flow chart of Fig. 11, one embodiment of a method for 
determining a set of TEQ coefficients to be used to generate a signal vector Zk in 
accordance with the present invention. Initially, in step 1100, the combination of the 
output of the h channel and the disturbance vector, yk, is sampled. In step 1102, the 
hypothetical delay channel d is set. The impulse response length of the target channel (t„) 
is determined in step 1104. Optimal TEQ filter coefficients {wfc} are determined in step 
1 106, such that the number of bits of data loaded per symbol (S) is maximized while the 
channel impulse response is minimized to provide an output with minimal noise and 
heightened data density. In step 1108, an equalizer coefficient vector is calculated 
based upon the TEQ filter coefficients defined in step 1106. In effect, the response Zk is 
compared, as in step 1110, with the target impulse response channel (f„) vector b to 
generate optimal TEQ filter coefficients that result in minimizing the error of ek. By 
minimizing the error between the channels, the inventive method arrives at a set of 
coefficients Wk and vector to yield a shortened channel impulse response Zk that 
approximates the target channel impulse response. In a one embodiment, the Zk vector 
preferably has a length Nt and is the target impulse response vector. 

Referring now to the flow chart of Fig. 12, one embodiment of the operation of 
step 1106 is described. In step 1202 the original long channel impulse response hk is 
determined. In step 1204, the noise autocorrelation sequence, r^, is determined. In step 
1206, the delay value, d, is fixed as the starting location of the non-zero segment of the 
target impulse response. Similarly, a value for L is chosen and fixed as the center of the 
range of possible values that L can take, where L is calculated as: 




in step 1208, where L is an integer value used to set the target value of the length of the 
desired signal Nr. With hk, r^, dmdL known or fixed at certain values, the error between 
the parallel branches Zk and bk may be minimized in step 1210. 
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The specifics of step 1210 are discussed in more detail with reference to Fig. 13. 
In particular, Fig. 13 details an embodiment of a process used to calculate the TEQ filter 
{wk} and TIR fiher {h] coefficients. In order to minimize the error between Zk and bk, a 
MLC-TEQ mathematical method is constructed in step 1300. In order to avoid the trivial 
5 all-zeros solution, a finite length constraint is imposed on or w in step 1302. In the 
example of step 1302, one of the received signal channels, or "taps", of b is constrained 
as bi = c, where L g {0,...JSfT-l } and c e and c 9t 0. In this example, c is chosen to be 
c = 1; this is done without a loss of generality. 



A matrix F is constructed in step 1304 as: 



F=l 



Ou Il>L Ol.1 Ol,NT-L-\ OL,NC+NTEQ-NT-d-\ 



A covariance matrix, Rv, is constructed in step 1306 as: 



AV(0) 



rv(0) 



^vNTEQ,NTEQ 



ry(NTEQ-l) (Nteq-2) ... 



A matrix H is constructed in step 1308 as: 



H = 



ho hi 
0 ho 




0 



0 ho 



15 



Further, in step 1310, a matrix h is constructed for d+L < Njeq as: 
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^= Ij'd + L - ^0 ^l,NTEQ-d-L-l ] 

and for d+L > Njeq in step 13 12 as: 

^ = t'^Z + L ••• ^ d + L-NjEQ-l ] 

The Nteq fir TEQ coefficients {w^} are calculated in step 1314, as are the target 
5 impulse response coefficients {K] in step 1316. 

Returning now to Fig. 12, once the above values have been calculated, the various 
F, Rv, H and h and the coefficients {wu} are then used to calculate the Equalizer 
Coefficient vector in step 410 as: 

=h [rM + H(I-F^F)H^y 

10 where: h is a function of the impulse response coefficient; Rv nteq,nteq is a noise 

2 

autocorrelation function; is the variance of x^; H is a function of the channel 
impulse response; I is a function of the energy of the ISI and ICI interferences; F is an 
intermediate variable; and 




T T 

15 or the change from Wo to w^teqa - 

It should be understood that the choices of the parameters d and L has a certain 
impact upon the performance of the TEQ filter with respect to a chosen application. 
Relating specifically to a DMT application, a reasonable capacity performance is 
obtained by choosing d as the location of the maximum value of the impulse response 

20 {h}. 
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Further, it has been observed that for a typical scenario, there is a relatively wide 
region around dc where the performance of the filter does not change, where dc is the 
effective delay corresponding to the starting location of the non-zero segment of the 
impulse response. For the L parameter, a reasonable choice is given by the equation: 




where [xl is a function representing the smallest integer that is greater than or equal to 
the number x. Therefore, L is chosen as the center of the range of possible values that L 
can take. 

From the detailed description above, it will be clear to one skilled in the art that 
10 the present invention has many benefits. In particular, the fundamental advantages are 
% two fold: it provides linear TEQ filtering with near-optimal performance, and it is 

5; structurally suitable for adaptive implementation on a real system. In particular, and in 

|;3 contrast to the filtering methods currently used in the art, this method includes: the 

Target Impulse Response (TIR) vector is the combined response of the transmission 
fy 15 channel and the TEQ filter is used as the search vector; the MLC-TEQ mathematical 
L; method constrains one element of the TIR vector to be equal to a constant and the 

:: ^ element can be any element of the TIR vector; the error is computed using the difference 

CO between the TEQ output and the TIR filter output; the TEQ filter coefficients are 

[J computed by minimizing the Mean Square Error (MSE) criterion; and ±e mathematical 

20 method provides a family of TEQ vectors which are parametized by two quantities, the 
location of the constrained element of the TIR vector and the delay value used in the 
computation. 

In its Hadrian™ and Antoninus™ products, Virata Corporation of Santa Clara, 
California, extends the benefits of an mtegrated full-rate ADSL CPE chipset. The 
25 inventive concepts discussed above may be incorporated into an integrated ADSL CPE 
processor and Analog Front End/Line Driver (AFE/LD) chipset, such as Virata 
Corporation's Hadrian^M and Antoninus™, which may be used in a wide variety of 
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applications. According to one embodiment of the present invention, the inventive 
concepts related to echo cancellation fianctionality and TEQ functionality may be 
incorporated into the Hadrian and/or Antoninus products. 

FIGs. 14a and 14b are schematic diagrams of hardware architectures in which the 
5 inventive aspects of the present invention may be incorporated. FIG. 14a illustrates a 
block diagram of a chip architecture 1400 for Hadrian 1, which includes an integrated 
ADSL CPE processor 1402 and AFE/LD chipset 1440. The integrated ADSL CPE 
processor 1402 may be delivered as a multi-chip module (MCM) including Z3 chip 1412 
and Domitian Chip 1410. Z3 chip 1412 is full-rate ADSL Physical Layer (PHY) for CPE 
10 with on-chip DP (e.g., DSL PHY Processor) code storage memory. Domitian chip 1410 
is a high performance communications processor for CPE with Ethernet PHY. Hadrian 
AFE/LD 1440 is an AFE with integrated line driver for full-rate ADSL CPE, as a part of 
the chip-set. The Hadrian AFE/LD 1440 is an integral part of the complete solution. The 
Hadrian Integrated ADSL CPE Processor 1402 is compatible with the Hadrian AFE/LD 
15 1440. 

The Hadrian- 1 chipset, as shown in FIG. 14a, is designed to be fully compliant 
with the full-rate ADSL ITU standard G.992.1 (G.dmt) and the splitterless ADSL nU 
standard G.992.2 (G.lite). Hadrian- 1 fully supports Annex A, both Frequency Division 
Duplex (FDD) and Echo Cancelled (EC) modes, and Annex B of G.992.1 and Annex A 

20 and B of G.992.2. In addition, the initialization procedure is fully compUant with 
G.994.1 (Rev. 2) (G.hs.bis). Other features may include being fully compliant with the 
splitterless ADSL FTU standard G.992.2 (G.lite) and supporting botii Annex A and B. 
Hadrian 1 may also include a communications processor with Protocol Processor (PP) for 
protocol execution and Network Processor (NP) for data manipulation. Other features 

25 may include DSL PHY Processor (DP) for implementing modem firmware; Internal 
10/100 Ethernet PHY (disabled when Media Independent Interface (Mil) interface is 
used); 10/100 Ethernet MAC with ME for connecting to either internal 10/100 Ethernet 
PHY or external 10/100 multi-PHY; External Peripheral Bus (EPB); Synchronous 
Transfer Mode (STM): Serial firame data (e.g., High-Level Data Link Control (HDLC)); 
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simultaneous STM and ATM support; bearer channels ASO, ASl, LSD, LSI for both 
STM and ATM; single and dual latency paths for both downstream and upstream; four 
framing modes, e.g., modes 0, 1, 2, and 3; Network Timing Reference (NTR) transport 
support; dying gasp detection and handling; Universal Serial Bus (USB) 1.1 slave; 
5 integrated line driver and Voltage Controlled Crystal Oscillator (VCXO) for the AFE; 
general purpose input/output (GPIO); universal asynchronous receiver/transmitter 
(UART); In-Circuit Emulator (ICE); and/or Joint Test Action Group (JTAG). 

In particular, standard compliance includes the power spectral density (PSD) of 
the transmit signals for all supported annex and corresponding modes; the use of 

10 frequency bins for transmit and receive signal including pilot bins; handshake procedure 
as specified in G.994.1; various initialization, training, and message signals; state 
machine and tuning sequence; DMT modulation; framing modes; bearer channels and 
dual latency paths; Embedded Overhead Control (EOC) channel; ADSL Overhead 
Control (AOC) Chaimel; forward error correction; inter-leaver operation; and ATM and 

15 STM functionalities. Hadrian-1 is interoperable with standard compliant central office 
(CO) equipment, including various DSL Access Multiplexor (DSLAM) vendors. 

FIG. 14b illustrates Hadrian 2, which includes an integrated ADSL CPE 
Processor 1452 and AFE/LD 1460 chipset, as shown by 1450. Hadrian 2 ADSL CPE 
processor 1452 may be delivered as a single-chip and cost-optimized device, which 

20 includes Z3 chip and Domitian chip. Z3 chip is a full-rate ADSL PHY for CPE without 
on-chip DP code storage memory. Domitian chip is a communications processor for CPE 
with Ethernet PHY and with SDRAM interface capable of handling various processors, 
such as Network Processor (NP), Protocol Processor (PP) and DSL PHY Processor (DP). 
Hadrian AFE/LD 1460 is an AFE with integrated line driver for full-rate ADSL PHY for 

25 CPE and will also be included as part of a chip-set. Hadrian 2 may support the above 
listed features for Hadrian 1 in addition to STM: TDM H.110, ST-Bus. 

The Domitian communications processor has been architected around the 
principle that there are two functions of a communications system which may use 
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different architectures. These two functions are data manipulation and protocol 
execution. 

Data manipulation involves many word, byte and bit changes on small amounts of 
data. These operations have a deterministic character and are finished in a short time 
5 span. The code controlling these operations are small and compact, often written in 
assembly language, and involves a detailed knowledge of low level data protocols (Open 
Source Initiative (OSI) layer 1 to layer 3) and the available hardware. Data is processed 
in cells and packets of limited size. 

The protocol stack routines are multitasking, involving a large amount of memory 
10 and although time limits are set, these are not as strict as for the low level data 
manipulation routines. The data consists of frames which can be large (e.g., up to 64K). 

The Domitian architecture reflects these two types of function. The Protocol 
Processor (PP) has a 4 KB cache and is thus suited for running large programs. It has no 
direct access to the network data port but can exchange data with the Network Processor 

15 (NP) using shared Synchronous Dynamic Random-Access Memory (SDRAM). Large 
frames of data may be easily exchanged between the two processors using this method. 
The main PP tasks are to set up and close connections, get data from the NP, convert the 
data from one protocol type to another and pass them back to the NP again to be 
transferred to another network interface. For protocol support, it may also generate its 

20 own data frames for signalling, operating and maintenance. The PP may also 
communicate with, and control external hardware using the External Peripheral Bus 
(EPB). 

The Network Processor (NP) has a dedicated local program memory (e.g., 16 KB 
of SRAM) and may directly interact with network ports and associated hardware. A 
25 main tasks involves assembling incoming packets into frames for each of the network 
connections. It knows the status of each network port and responds to any incoming 
packet/cell in time to prevent buffer overflow. While receiving packets/cells, it 
assembles them into frames, keeps track of errors, gathers statistical data, performs 
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policing, extraction of Operation, Administration and Maintenance (0AM) cells, etc. 
When transmitting data, it segments frames into packets/cells, transmits at a specified rate 
by inserting idle cells, adds Cyclic Redundancy Check (CRC) bytes, inserts OAM cells, 
etc. 

5 FIG. 15 is a block diagram of a physical media dependent (PMD) layer 1500 of a 

ADSL CPE chip in which the inventive aspects of the present invention may be 
incorporated. ¥IG. 15 illustrates core building blocks for the PMD layer and basic signal 
flow. As shown in FIGs. 14a and 14b, PMD 1430 is implemented in ADSL CPE 
Processor 1402 and 1452. 

10 PMD layer may include a variety of functions, which may include a DSL PHY 

Processor (DP) for implementing modem firmware; a complete DMT engine including 
IFFT (e.g., 64-point, 128-point or multiples thereof) on the transmit path and a point Fast 
Fourier Transform (FFT) (e.g., 512-point) on the receive path, Tx/Rx Bit Extract, CycUc 
Prefix, and Constellation encoder/decoder; a Forward Error Correction (FEC) mechanism 

15 including the mandatory Reed Solomon (RS) encoder/decoder and optional Trellis 
encoder/decoder; both fast and interleaved paths are supported along with the 
Interleaver/deinterleaver; Training Signals Generator and Sync Symbol Generator; 
Course/Fine Gain Scaling and Tx/Rx Clip Scaling; Programmable Transmit Filter and 
Receive Noise Reduction Filter; Digital Automatic Gain Control (AGC); Adaptive Time 

20 domain Equalization (TEQ); Adaptive Frequency domain Equalization (FEQ); Tone 
ordering and Bit Swap; Clock Recovery Loop (CRL); Sigma-Delta Interpolator and 
Decimator for Digital to Analog Converter (DAC) and Analog to Digital Converter 
(ADC); and Adaptive Echo Cancellation Filter. 

As shown in FIG. 15, adaptive echo canceller 1510 may embody the inventive 

25 aspects related to echo cancellation of the present invention discussed above. In addition, 
adaptive TEQ 1520 may embody the inventive aspects of the TEQ of the present 
invention discussed above. 
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FIG. 16 is a block diagram of a transmission convergence (TC) layer 1600 of a 
ADSL CPE chip in which the inventive aspects of the present invention may be 
incorporated. As shown m FIGs. 14a and 14b, TC 1420 is implemented in ADSL CPE 
Processor 1402 and 1452. The TC layer may support a variety of features, such as ATM- 
5 TC; STM-TC; dual-bearer; simultaneous ATM and STM transport; Bearer Channel 
Switch; UTOPIA 2 interface; ADSL Overhead Control/Embedded Overhead Control 
(AOC/EOC) Buffers; Tx/Rx CRC; and Scrambler/Descrambler. 

FIG. 17 is a block diagram of an analog front end device in which the inventive 
aspects of the present invention may be incorporated. Hadrian AFE/LD, as shown by 

10 1440 and 1460 in FIGs. 14a and 14b, with integrated line driver is an integral part of the 
complete solution. To achieve enhanced performance the Hadrian AFE/LD and its 
Hadrian Integrated ADSL CPE Processor counterpart are designed with tightly coupled 
architecture. AFE features may include an integrated line driver; an integrated VCXO; 
16-bit DAC with 14.5 effective bits; 16-bit ADC with 13.5 effective bits; industrial 

15 temperature range: -40C ~ 85C; and external filters. 

FIGs. 18a-18c are a block diagram of applications in which the inventive aspects 
of the present invention may be incorporated. FIG. 18a illustrates an Ethernet 
Router/Bridge 1800 which incorporates the Hadrian product. FIG. 18b illustrates a USB 
Modem and USB- Attached Gateway 1820 which incorporates ttie Hadrian product. FIG. 

20 18c illustrates an Integrated Access Device (IAD) 1840 which incorporates the Hadrian 
product. 

Vkata's Antoninus is a full-rate ADSL CPE PHY device comprised of two chips, 
which includes an ADSL CPE Processor called Z3 (as discussed above in connection 
with Hadrian 1) and a AFE/LD chipset, as illustrated in FIG. 17. The Z3 chip is a fuU- 
25 rate ADSL PHY for CPE with on-chip DP (e.g., DSL PHY processor) code storage 
memory. The ADSL CPE processor Z3 is also used in Hadrian 1, discussed above. 
Similarly, the inventive aspects related to the echo canceller and the TEQ may be 
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implemented in the Antoninun product. Antoninus AFE/LD is an AFE with integrated 
line driver for full-rate ADSL CPE, which is also included as part of the chip-set. 

While the foregoing description includes many details and specificities, it is to be 
understood that these have been included for purposes of explanation only, and are not to 
5 be interpreted as limitations of the present invention. Many modifications to the 
embodiments described above can be made without departing from the spirit and scope of 
the invention. 

The present invention is not to be limited in scope by the specific embodiments 
described herein. Indeed, various modifications of the present invention, in addition to 

10 those described herein, will be apparent to those of ordinary skill in the art from the 
foregoing description and accompanying drawings. Thus, such modifications are 
intended to fall within the scope of the following appended claims. Further, although the 
present invention has been described hereui in the context of a particular implementation 
in a particular environment for a particular purpose, those of ordinary skill in the art will 

15 recognize that its usefulness is not limited thereto and that the present invention can be 
beneficially implemented in any number of environments for any number of purposes. 
Accordingly, the claims set forth below should be construed in view of the full breath and 
spirit of the present invention as disclosed herein. 
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